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(54) Computerized music system having software and hardware sound sources 



(57) A musical sound generating apparatus creates 
a waveform to generate a musical sound according to 
performance information. In the apparatus, a first wave- 
form generator (21 ,22) is operable for creating a wave- 
form. A second waveform generator (10) is operable 
independently from the first waveform generator for cre- 
ating a waveform. An input device (14) provides per- 
formance information. A designating device designates 
at least one of the first waveform generator (21 ,22) and 
the second waveform generator (1 0) in correspondence 
with the provided performance information. A controller 
selectively operates the designated one of the first 



waveform generator (21,22) and the second waveform 
generator (10) to create the waveform according to the 
provided performance information. An output device 
(23) generates the musical sound based on the created 
waveform. The second waveform generator (10), the 
input device (14), the designating device and the con- 
troller are integrated with each other to constitute a 
main part composed of a computer, while the first wave- 
. form generator (21,22) alone constitutes a supplemen- 
tary part which is separate from the main part and which 
is optionally installable in the computer. 



FIGURE 1 




EP 0 747 877 A2 



Description 

BACKGROUND OF THE INVENTION 

The present invention relates to a musical sound generator employed in computer application systems using CPU, 
such as electronic game machines, network karaoke apparatuses, personal computers etc.. and more particularly 
relates to a musical sound. generator capable of generating various musical sounds according to performance informa- 
tion. 

Conventionally, in an apparatus such as a personal computer, musical sound can be reproduced by means of a 
specialized hardware module such as a sound source LSI and a sound source board, and by executing programs to 
control the installed sound source device. Recently, performance of CPU in the personal computer is remarkably 
improved so that the musical sound can be generated by the CPU in place of the specialized hardware module. This 
sort of the musical sound generation is called "software sound source" in contrast to "hardware sound source" which 
generates musical sound by the specific hardware. The CPU computes waveform data of musical sound according to 
a specific program. The quality of the sound generated by the software sound source depends upon the performance 
of the CPU executing the program. If the CPU has high performance, the waveform data can be computed at high 
speed so that a sampling frequency of the waveform data can be raised high to realize high quality musical sound gen- 
eration. However, if the CPU performance is poor, it is. difficult to compute the data at high speed so that the sampling 
frequency must be lowered. This inevitably results in poor quality of the reproduced musical sound, 

From system to system, there is a wide variety in the configuration of the application systems such as the personal 
computer, with respect to installation of optional devices. Generally, the optional device includes a hard disk, a video 
card etc., in broader meaning. However, in the present invention, the optional device means an externally connedable 
device involved in the musical sound generation. It should be noted that the processing ability of the CPU may be dif- 
ferent in various system configurations. Further, in a situation where an application program to generate sound and 
another application program to execute other jobs are simultaneously invoked in parallel, a load of the CPU may vary 
dependently on the running status of the programs and on the status of tasks currently executed in the system. In this 
fashion, the effective processing power of the CPU may vary in the same system. Thus, a user must rearrange basic 
setup for the sound generation whenever an environment of the system is changed, and that is very laborious. In such 
systems, the user cannot recognize whether the sound is not generated correctly in a current configuration setup, until 
any miss and skip of tone occurs at the actual reproduction of the sound. In other words, it is impossible to evaluate, 
whether the system configuration is reasonable until the sound is actually reproduced. Further, no matter how the CPU 
performance is high, an external sound generation hardware may be utilized in many cases according to the user's 
desire in practical use of the hardware resource. In such cases, full use of the hardware sound source may cause a 
problem that it is impossible to generate a sound surpassing the limitation of the facility of the sound generation hard- 
ware. A variety of tones cannot be reproduced. A number of timbre kinds cannot be increased even if there is a suffi- 
cient processing power I n the CP U. 

SUMMARY OF THE INVENTION 

The purpose of the present invention is to solve the problems described above, and Is to provide a musical sound 
generator capable of generating various musical sounds with retaining excellent quality of the sounds. 

According to the invention, a musical sound generating apparatus creates a waveform to generate a musical sound 
according to performance information. The apparatus comprises first waveform generator means operable for creating 
a waveform, second waveform generator means operable independently from the first waveform generator means for 
creating a waveform, input means for providing performance information, designating means for designating at least 
one of the first waveform generator means and the second waveform generator means in correspondence with the pro- 
vided performance information, controller means for selectively operating the designated one of the first waveform gen- 
erator means and the second waveform generator means to create the waveform according to the provided 
performance information, and output means for generating the musical sound based on the created waveform. 

Specifically, the input means comprises means for providing performance information which contains timbre infor- 
mation effective to specify a timbre of the musical sound and timing information effective to specify a timing of genera- 
tion of the musical sound. Further, the designating means comprises means for designating one of the first waveform 
generator means and the second waveform generator means in correspondence with the timbre information so that the 
output means generates the musical sound having the specified timbre at the specified timing. 

The designating means may include means operable if desired for coincidently designating both of the first wave- 
form generator means and the second waveform generator means so that the controller means operates both of the 
first waveform generator means and the second waveform generator means to concurrently create waveforms in paral- 
lel manner. 

The input means may comprise means for providing performance information effective to command concurrent 
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generation of a plurality of musical sounds. Further, the designating means may comprise means for designating one 
of the first waveform generator means and the second waveform generator means according to a number of concurrent 
musical sounds specified by the performance information such that the designated one has a capacity suff iciertl to cre- 
ate a number of waveforms corresponding to the number of the musical sounds. 

The designating means may further comprise means operative when the number of the concurrent musical sounds 
exceeds a capacity of either of the first waveform generator means and the second waveform generator means for des- 
ignating both of the first waveform generator means and the second waveform generator means to ensure complete 
generation of the concurrent musical sounds. 

The first waveform generator means may comprise an external waveform generator optionally connectable to the 
controller means while the second waveform generator means may comprise an internal waveform generator inte- 
grated with the controller means so that the designating means designates the internal waveform generator in place of 
the external waveform generator when the same is not connected to the controller means even though the external 
waveform generator should primarily correspond to the provided performance information. 

The second waveform generator nieans, the input means, the designating means and the controller means may be 
integrated with each other to constitute a main part composed of a computer, while the first waveform generator means 
alone constitutes a supplementary part which is separate from the main part and which is optionally installable in the 
computer. 

The first waveform generator means may be composed of a hardware module driven by the controller means, while 
the second waveform generator means may be composed of a software module installable in the controller means. 

The second waveform generator means may comprise a plurality of digital waveform generators which are opera- 
ble based on different algorithms to arithmetically create digital waveforms having different qualities. Further, the con- 
troller means may comprise means for selectively operating an optimal one of the digital waveform generators 
according to the provided performance information. 

The second waveform generator means may include a digital waveform generator of a waveform memory type 
operable based on a relatively simple algorithm to create a digital waveform having a relatively low quality, and another 
digital waveform generator operable based on a relatively complicated algorithm to create another digital waveform hav- 
ing a relatively high quality. ^ 

The second waveform generator means may comprise a computerized waveform generator operable according to 
a given algorithm at a variable operation speed to create a digital waveform by successively computing sample values 
of the digital waveform. Further, the controller means may comprise means for provisionally operating the computerized 
waveform generator to carry out trial creation of a mode! digital waveform while measuring the operation speed at which ' 
the trial creation is carried out, determining means for optimally determining a sampling frequency comparable to the 
measured ( OpWBtionspeed, and means for actually operating the computerized waveform generator to enable the same 
to successTvelTcompuiTsample values of an actual digital waveform at the determined sampling frequency according 
to the provided performance information. - 
The determining means may comprise means for fixing the sample frequency to one of stepwise predetermined 
levels, which is lower than and closest to the measured operation speed. 

The controller means may further comprise changing means operative when the determined sampling frequency 
falls below a critical level which is defined to ensure' a minimal quality of the digital waveform for changing the algorithm 
to raise the operation speed of the computerized waveform generator so that the sampling frequency can be redeter- 
mined to exceed the critical level. 

The changing means may comprise means for changing the .algorithm from a complicated one to a simplified one 
such that the computerized waveform generator operates based on the simplified one of the algorithm to successively 
read out prestored ones of sample values to reproductively create the digital waveform. 

According to another aspect of the invention, a sound generating apparatus creates a digital waveform to generate 
a musical sound according to performance information. The apparatus comprises input means for providing perform- 
ance information, computerized waveform generator means operable based on a given algorithm at a variable opera- 
tion speed to create a digital waveform by successively computing sample values of the digital waveform, trial means 
for provisionally operating the computerized waveform generator to carry out trial creation of a model digital waveform 
while measuring the operation speed at which the trial creation is carried out, determining means for optimally deter- 
mining a sampling frequency comparable to the measured operation speed, controller means lor actually operating the 
computerized waveform generator to enable the same to successively compute sample values of an actual digital wave- 
form at the determined sampling frequency, and output means for generating the musical sound based on the actual 
digital waveform according to the provided performance information . 

In the inventive apparatus/the input means provides the performance information, and the designating means 
specifies which of the waveform generator means should generate a waveform of the musical sound relevant to the per- 
formance information. The waveform generator means specified by the designating means is controlled to generate the 
waveform of the musical sound relevant to the performance information. Thus, the performance information itself can 
specify which of the first and second waveform generator means should generate the waveform of the musical sound 
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characterized by the performance information. The first and second waveform generator means are different from each 
other in their structure so that their processing load and- characteristics of the generated sound may differ in the wave- 
form generation between the first and second waveform generator means. Therefore, it is possible to generate various 
musical sounds by selecting the first waveform generator means for generation of the waveform of the musical sound 
5 relevant to a certain event of the performance information, and by selecting the second waveform generator means tor 
generation of the waveform of the musical sound relevant to another certain event of the performance information. Fur- 
ther, it is possible to adjust the processing load by controlling the allocation of the waveform generator means to the 
performance information. 

It is preferable to determine which of the waveform generator means to generate the waveform of the musical 
w sound according to a timbre of the musical sound to be generated, because a certain type of the waveform generator 
means deserves an optimal creation of a certain timbre. The preferred waveform generator means to generate the 
waveform of the musical sound relevant to the performance information is determined according to the timbre specified 
by the performance information in the invention. The timbre information maybe included in the performance information 
in the invention. As described above, due to the difference between the first and second waveform generator means, 
16 the characteristics of the musical sound may differ even if the same performance information is provided. In other 
words, various waveforms of the musical sound can be reproduced. With generating the waveforms of the musical 
sound simultaneously by both of the first and second waveform generator means according to the same performance 
information, variations of the musical sound can be realized for a common timbre by using the different waveform gen- 
erator means. 

20 Due to conditions of the musical sound generating, there may be a situation where a waveform of the musical 
sound should be generated by a substitute waveform generator means, even if a primary waveform generator means 
should deserve to generate the waveform according to the performance information. For example, this substitution may 
take place when the sound generating capacity of the primary waveform generator means almost reaches its maximum 
ability. In the invention, in addition to the performance information, the number of the generated waveforms of the musi- 

25 cal sound is taken into account for determining which of the waveform generator means should generate the musical 
sound in order to prevent overflow of the waveform computation. 

By the way, the first and second waveform generator means are the same in their waveform generating function, so 
that the user may not use both, but may use only one. For example, the first waveform generator means is detachable 
while the second waveform generator means is permanently installed. In the invention, if the first waveform generator 

30 means exists and the waveform of the musical sound relevant to the performance information should be generated by 
the first waveform generator means, the first waveform generator means is designated to generate the waveform of the 
musical sound relevant to the performance information. Otherwise, the second waveform generator means may be des- 
ignated to generate the waveform of the musical sound relevant to the performance information if the first waveform 
generator means is incidentally detached from the apparatus. The waveform of the musical sound originally to be gen- 

35 erated by the first waveform generator means can be generated alternatively by the second waveform generator means. 
Thus, even if thef irst waveform generator means does not exist, the waveform of the musical sound is safely generated. 

In the invention, the first and second waveform generator means can respectively compute sample values of the 
waveform of the musical sound. The trial means measures a time required for the second waveform generator means 
to generate the waveform of the musical sound. The sampling frequency is determined according to the time measured 

40 by the trial means. Thus, the musical sound can be generated at the optimum sampling frequency for the system con- 
figuration., Generally, if the sampling frequency is varied continuously, an arrangement to handle the frequency deter- 
mination tends to become complicated. However, in a specific form of the invention, the sampling frequency determined 
by the determining means is selected from stepwise predetermined levels. 

If the sampling frequency determined by the determining means is lower than the critical level, the computation 

45 process of the waveform is changed since the quality, of the generated sound is not retained by the original waveform 
generation at the determined sampling frequency. In this case, it is preferable to change the computation process such 
as to simply read out sample values of the waveform of the musical sound in order to raise the sampling frequency. 

BRIEF DESCRIPTION OF THE DRAWINGS 

so 

Figure 1 is a schematic block diagram illustrating a first embodiment of the inventive musical sound generator. 
Figure 2 is a schematic block diagram illustrating a variation of the embodiment shown in Figure 1 . 
Figure 3 is a schematic block diagram illustrating another variation of the embodiment shown in Figure 1 . 
Figure 4A is a schematic block diagram illustrating an arrangement in which a sound source device and its periph- 
55 eral devices are integrated with each other., 

Figure 4B is a schematic block diagram illustrating an arrangement in which a DSP and its peripheral devices are 
integrated with each other. 

Figure 5 illustrates operating modes in the first embodiment according to the present invention. 
Figure 6 is a memory map of a RAM provided in the first embodiment. 
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Figure 7 is a flowchart illustrating an overall process executed in the first embodiment. 
Figure 8 is a flowchart illustrating a waveform synthesizing program executed in the first embodiment. 
Figure 9 is a flowchart illustrating the waveform synthesizing program executed in the first embodiment. 
Figure 10 is a flowchart, illustrating the waveform synthesizing program executed in the first embodiment. 
s Figure 11 is a flowchart illustrating the waveform synthesizing program executed in the first embodiment. 

Figure 12 is a flowchart illustrating the waveform sample value loading process executed in the waveform synthe- 
sizing program. 

Figure 13 is a flowchart illustrating the waveform sample value computation process executed in the waveform syn- 
thesizing program. 

10 Figure 1 4 is a flowchart illustrating the waveform sample value computation executed by CPU in the waveform syn- 
thesizing program. 

Figure 15 is a flowchart illustrating the synthesizing process by a selected hardware in the waveform synthesizing 
program. 

Figure 1 6 is a flowchart illustrating the synthesizing process by the selected hardware in the waveform synthesizing 
is program. 

Figure 1 7 is a flowchart illustrating a timer process in the waveform synthesizing program. 

Figure 1 8 is a flowchart illustrating a synthesizing process by a selected hardware in a second embodiment. 

Figure 1 9 is a flowchart illustrating a synthesizing process by a selected hardware in a third embodiment. 

Figure 20 is a flowchart illustrating a synthesizing process by a selected hardware in a fourth embodiment. 
so Figure 21 is a schematic block diagram illustrating a variation to which the present invention is applied. 

Figure 22 is a schematic block diagram illustrating another variation to which the present invention is applied. 

Figure 23 is a schematic block diagram illustrating a further variation to which the present invention is applied. 

Figure 24 is a schematic block diagram illustrating a still further variation to which the present invention is applied. 

Figure 25 is a schematic block diagram showing an additional embodiment of the inventive musical sound gener- 
ss ating apparatus. 

DETAILED DESC RIPTION OF THE INVENTION 

Details of embodiments of the present invention will be described hereunder with reference to the drawings. Figure 
30 1 is a schematic block diagram showing a first embodiment of a musical sound generator according to the present 
invention, in Figure 1, numeral 10 denotes a CPU, which controls various units composing a computer system via a 
data bus 12, according to a basic program stored in a ROM 1 1 . Numeral 13 denotes a RAM temporarily storing various 
registers, flags and data. Numeral 14 denotes an I/O port of the multi type which receives and transmits MIDI informa- 
tion, key information provided upon key operation of a keyboard (not shown), and other miscellaneous information via 
ss various interfaces l/F (hot shown). The multi type i/O port 14 receives performance information in the form of the MIDI 
information or the key information KBD. In the present embodiment, it is assumed that the performance information may 
be generated by an automatic performance program. In this case, the automatic performance program means that the 
performance information is. generated in time series by a certain automatic sequence program. Therefore, fie arrange- 
ment shown in Figure 1 works not only as a musical sound generator but also a sequencer. The type of l/F may be a 
40 serial or parallel port, RS-232C, RS-422 and so on. Especially in case of RS-232C, the computer system communicates 
with a host station through a public telephone network by a modem (not shown). Thus, the input source of the perform- 
ance information may be the keyboard in case that the keyboard operation information is provided, or an external device 
connected through the l/F in case that the MIDI information is provided, or a sequence program executed by the CPU 
in case that the automatic performance information is provided. Numeral 1 5 denotes a storage unit, which is comprised 
45 of FD (Floppy Disk) or HD (Hard Disk). The storage unit 1 5 further stores application programs and data. Numeral 1 6 
denotes a display which is composed of CRT or LCD (Liquid Crystal Display). The display 16 presents various data 
under the control of the CPU 10. Numeral 17 denotes an optional co-processor which executes floating point computa- 
tion instead of the CPU 10. The rest of data processing is carried out by the CPU 10. Numeral 18 denotes a timer which 
counts time in timer processing described later. Numeral 1 9 denotes a DMAC (Direct Memory Access Controller) which 
so transfers data to and from RAM 20 directly without the control by CPU. Nowadays, the co-processor 1 7, timer 1 8 and 
DMAC 19 may be accommodated in a single chip together with CPU 10, though these are discrete devices in the 
present embodiment. Numeral 20 denotes a RAM whioWias a^tructure similar to the first-mentioned RAM 13 with 
respect to its hardware construction. However, the RA^^3/is^JeBd as a work area for the program execution by the 
CPU, while the other RAM 20 is a waveform memory which temporarily stores a waveform represented by wave data. 
55 Numeral 21 denotes a DSP (Digital Signal Processor) for use in digital signal processing required for musical sound 
synthesis. Numeral 22 denotes an optionaUound source which constitutes a first waveform generator of one chip LSI 
for generating a waveform of the musical sound according to performance information. Numeral 23 denotes a D/A con- 
verter which is enabled when a flag DACENBL is set to "1". Before the D/A converter 23, an FIFO data buffer (not 
shown) is normally provided. The wave data stored in the FIFO is read out at a sampling frequency fs. After the D/A 
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converter 23, an LPF (Low Pass Filter) is normally provided (not shown). A cutoff frequency of the LPF is set to about 
half of the sampling frequency fs. The LPF is an output device of the musical sound generator. The musical sound is 
reproduced through an amplifier and a speaker. Numeral 24 denotes a RAM which is structured similarly to the RAM 
1 3 or 20 with respect to its hardware construction. The RAM 24 is utilized as a work memory for the arithmetic operation 
of the DSP 21 . Numeral 25 denotes a waveform memory which stores wave data of basic or typical timbres in case that 
the sound source 22 generates a musical sound according to a waveform memory readout method. Trie role of the 
waveform memory 25 and the RAM 20 is slightly different in a manner that the waveform memory 25 is used mainly by 
the sound source 22 and is provided in the form of ROM or a daughter board, while the RAM 20 is utilized by the CPU 
10 as a waveform memory. 

Generally in the arrangement above, some devices such as co-processor 17, DSP 21, sound source 22, RAM 24 
and waveform memory 25 are often optionally installed according to user's choice. If the RAM 24 is not installed, a cer- 
tain area of the RAM 1 3 is allocated for the DSP 21 . The waveform memory 25 may not be installed if the sound source 
22 fs an FM synthesizing device which generates a musical sound by pure computation of wave data. The CPU 10 rec- 
ognizes whether these optional devices are installed or not. In the present embodiment, the CPU 10 recognizes the 
existence of the optional devices according to one of methods listed below: 

(1) A port address is reserved for a corresponding device connection. The CPU 10 accesses the port address 
immediately after power-on or reset of the system. If the CPU 10 detects a predetermined sign from the port 
address, it recognizes the existence of the corresponding device. 

(2) A jumper switch is provided for signifying the device installation. The user turns the switch on at the time of 
installing the corresponding device. 

(3) If the system is implemented as a personal computer, the optional devices are registered in a configuration file 
in terms of corresponding device drivers or in a batch file. The system software recognizes the devices through 
these files. 

All these optional devices are fully installed and connected to the data bus 1 2 in the present embodiment. However 
the connection port is not limited to the data bus 1 2. The optional devices may be connected via serial/parallel inter- 
faces, through which each device carries out data transaction mutually with the CPU 10. In other words, any kind of 
interface is possibly provided for the optional devices, provided that the device can communicate with the CPU through . 
the interface. For example, the sound source 22 may actually be provided as a sound source board 41 or an extension 
board as shown in Figure 2. In this case, the board 41 is inserted into a slot on a main board or mother board. The 
sound source board 41 communicates with the CPU 10 through the bus 12, l/F controller 26, and extension interface 
27. The waveform memory 25 may be installed through a socket provided on the sound source board 41 in this arrange- 
ment. Additionally, the extension interface 27 may be provided with an additional D/A converter 28. Othen/vise, the 
sound source 22 may be provided in the form of a discrete LSI chip, or mounted on the daughter board. The chip or 
daughter board is installed through a socket provided on the mother board or extension board in this arrangement. Sim- 
ilarly, the DSP 21 may be provided in the form of a DSP board 42. In this case, the DSP 21 communicates with the CPU 

10 via the extension interface 27. Otherwise, the DSP 21 may be provided in the form of a discrete LSI chip likewise the 
sound source 22. The input data is transferred to the D/A converter 23 through the bus 12 in Figure 1. However, the 
data can be distributed directly or through the extension interface, if the DSP 21 or sound source 22 is installed through 
the socket or the extension interface. 

As shown in Figure 3, a first waveform generator or sound source system 32 comprised of the sound source 22 or 
the DSP 21 can be connected to a local bus 33, through which the data is transferred to and from a CPU system 30 
without using the data bus 1 2. The CPU system 30 is composed of a standard arrangement including the CPU 1 0, ROM 

1 1 and RAM 1 3, while peripheral devices 31 include multi type I/O port 14, storage unit 1 5, and miscellaneous inter- 
faces and operators. The sound source system 32 is specifically composed of the discrete sound source 22 or DSP 21 
in the embodiment. However, in general, any functional elements for the musical sound generation are involved in the 
sound source system 32. The sound source system 32 may be integrated with or separated from the CPU system 30. 
Further, the connection interface can be provided at either of tie CPU side and the sound source device side. Namely 
any connection interface may be employed according to the inventive system setup. Additionally to the local bus, any 
sort of interface/protocol combination such as MIDI, RS-232C/422, IEEE P-1394, or SCSI may be employed. Also, com- 
munication network such as public telephone network may be used as the data communication media. 

In an arrangement shown in Figure 4A, the sound source device 22 may be integrated into a single chip, or into a 
printed circuit board module together with the waveform memory 25. and the D/A converter 23. Similarly, as shown in 
Figure 4B, the DSP 21 , RAM 24, and D/A converter 23 may be integrated altogether into a single chip. ■ 

The arrangements shown in Figures 1 to 3 are nothing but an example. The style of the device connection depends 
upon the individual system setup. Further, two or more of the functional elements shown in Figure 1 may be integrated 
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into a single chip. 

According to the invention, the above constructed musical sound generating apparatus creates a waveform to gen- 
erate a musical sound according to performance information. A first waveform generator such as the sound source 22 
or the DSP 21 is operable for creating a waveform. A second waveform generator composed of the CPU 10 is operable"] 
independently from the first waveform generator for creating a waveform. The I/0 14 provides performance information. 
One of the first waveform generator and the second waveform generator is designated in correspondence with the pro- 
vided performance information. The apparatus selectively operates the designated one of the first waveform generator 
and the second waveform generator to create the waveform according to the provided performance information. The 
DAC 23 generates the musical sound based on the created waveform. The first waveform generator comprises an 
external waveform generator optionally cpnnectable to the apparatus while the second waveform generator comprises 
an internal waveform generator integrated with the CPU 10. Occasionally, the internal waveform generator is desig- 
nated in place of the external waveform generator when the same is not connected to the apparatus even though the 
external waveform generator should primarily correspond to the provided performance information. The second wave- 
form generator is integrated with the CPU 10 to constitute a main part composed of a computer, while the first waveform 
generator alone constitutes a supplementary part which is separate from the main part and which is optionally installa- 
ble in the computer. The first waveform generator is composed of a hardware module driven by the CPU 10, while the 
second waveform generator is composed of a software module installable in the computer. 

Various operating modes in the present embodiment will be described hereunder. The operating modes of the 
inventive musical sound generator can be categorized, as shown in Figure 5, into two major groups, one of which 
relates to designation of a synthesizing method, and the other of which relates to allocation of a timbre to the different 
waveform generators. The two major groups are divided into more specific modes. First of all, the modes to specify the 
synthesizing method will be described hereunder. 

In the present embodiment, the sound generation is carried out by synthesizing a waveform or wave data of a musi- 
cal sound according to the performance information, and by converting it into an analog signal. The wave data can be 
generated in various methods. The used method is determined according to the operating mode in which the synthe- 
sizing method is specified. In the present embodiment, CPU synthesizing mode by the second waveform generator and 
sound source synthesizing mode by the first waveform generator are assumed by selection. 

In the CPU synthesizing mode, a musical sound is synthesized only by the CPU 10, or by combination of the CPU 
10 and the co-processor 17. Further, the CPU synthesizing mode, can roughly be divided into the following four sub- 
modes. The generated waveform is converted into an analog signal by the D/A converter 23 for acoustic reproduction. 

FM mode: This FM mode utilizes a software module of an FM sound source for synthesiz- 

! ing a sound. The wave data is generated by real-time FM modulation over a 
basic sine wave by means of the CPU 1 0. 

Harmonics synthesizing mode: The harmonics synthesizing mode Is such that a fundamental waveform and its 
harmonics are synthesized altogether. With the real-time operation by the CPU 
10, a fundamental waveform and its harmonics are calculated to synthesize the 
waveform. 

Wave form memory readout mode: In this mode, the sound is synthesized by accessing a waveform memory. Prior 
to the synthesizing, the CPU 10 loads a plurality of basic waveforms into the 
RAM 20. Upon a synthesizing command entry, the CPU generates the wave 
data of a specified timbre at a specified pitch and volume by reading out the 
waveform. In the waveform memory readout mode, it is possible to synthesize a 
sound even with a low performance CPU, since the synthesizing is carried out 
by accessing RAM or ROM to read out wave data. Thus, a work load of the CPU 
in this mode is smaller than that in the FM mode and the harmonics synthesizing 
mode. However, the RAM should be allocated with a wave data area, so that 
shortage of a tree area of the RAM 1 3 or 20 may be caused occasionally. Thus, 
the waveform memory readout mode may not be used preferably under some 
situations dependency on total RAM capacity and CPU addressing volume. 

Physical model synthesizing mode: In the physical model synthesizing mode, the sound generation mechanism of 
an actual musical instrument, such as air flow in a tube, is simulated by an elec- 
tronic model in order" to synthesize the sound. The wave data is computed with 
real-time operation of devices including the CPU 10. An example of the algo- 
rithm for the physical model synthesizing is disclosed in JP-A-63-401 99. 
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As listed above, the CPU-aided software sound source or the second waveform generator: includes a plurality of 
digital waveform generators which are operable based on different algorithms to arithmetically create digital waveforms 
having different qualities. The inventive apparatus selectively operates an optimal one of the digital waveform genera- 
tors according to the provided performance information. Specifically, the second waveform generator includes a digital 
waveform generator of the waveform memory readout type operable based on a relatively simple algorithm to create a 
digital waveform having a relatively low quality, and other digital waveform generators operable based on a relatively 
complicated algorithm to create another digital waveform having a relatively high quality. 

On the other hand, in the hardware sound source synthesizing mode, the musical sound is synthesized using a 
specific hardware such as the LSI sound source 22. As a matter of course, in this mode, the hardware module such as 
the LSI sound source 22 must be installed in the system. The LSI sound source 22 synthesizes the wave data by the 
FM mode or the waveform memory readout mode (likewise the software sound source). The synthesizing method is 
determined by the hardware itself. The CPU 10 does not cover the control of the native synthesizing process of the 
sound source 22. 

In the present embodiment, a multiple of voice channels are provided. One channel is allocated for one tone in 
either of the CPU synthesizing mode and the sound source synthesizing mode. A plurality of musical sounds are gen- 
erated in the multiple of the channels to realize concurrent sounding of the plural voices. Since the wave data can be 
synthesized by both of the CPU 10 and the sound source device 22 in the present embodiment, selection of the wave- 
form generators to be utilized is an important issue. In the present embodiment, optimum one of the waveform genera- 
tors is designated according to the voice allocation upon accepting a note-on command. The allocation mode includes 
the fallowings: 

CPU select mode: In the CPU select mode, the waveform synthesizing is effected by the CPU synthesizing 

mode at first priority. However, if the capability of the computing devices including the 
CPU 10 is not enough, the number of voice channels which can be used for the synthe- 
sizing is limited. In such a case, a part of the waveform synthesizing operation exceeding 
the capacity of the computing devices including the CPU 10 is carried out by the hard- 
ware sound source. 

Sound source select mode: In the sound source select mode, the waveform synthesizing is effected by the hardware 
sound source at first priority. However, if the capability of the hardware sound source 
device 22 is not enough, the number of the channels which can be used for the synthe- 
sizing is limited. In such a case, a part of the waveform synthesizing operation exceeding 
the capacity of the sound source device 22 is carried out by the CPU software sound 
source. 

In the manuaj mode, the user manually specifies either of the software and the hardware 
sound sources. Further, a specific synthesizing mode is designated if the CPU-aided 
software sound source is specified, 

In the compulsory mode, the sound source to be used is forcibly determined according to 
running state of application programs other than the sound generation program without 
regard to the user's intention. 

A memory map of the RAM i 3 or 20 will be described hereunder. The arrangement of the inventive musical sound 
generator is not so different from general personal computers. Further, the general personal computer can be used as 
the musical sound generator provided that it executes operations related to the waveform synthesis. Thus, the content 
of the RAM 13 or 20 is not so different from that of the personal computer. The memory space of the RAM 13 or 20 is 
divided into a plurality of areas as shown in Figure 6. In Figure 6, an OS area is occupied by the operating system as 
in the general personal computer. The application program areas (1 ) to (n) accommodate various application programs 
other than the waveform synthesizing program. These areas are allocated one by one for the invoked application pro- 
grams. Song data and other miscellaneous data are stored in a data area, while the wave data is loaded into a wave 
data area WAVE when the synthesizing is carried out by the waveform memory readout method. Lastly, a designated 
one of waveform synthesizing programs is stored in a waveform synthesizing program area. 

The operation of the musical sound generator according to the invention will be described hereunder. The musical 
sound is generated by executing a specific application program of the personal computer, namely, the waveform syn- 
thesizing program. Otherwise, the waveform synthesizing program may be implemented as a facility of the OS in the 
form of a transient program which is automatically installed at the time of boot-up of the system. Even though the mem- 
ory address and execution permission of the waveform synthesizing program depends on configuration of the OS envi- 
ronment, user operation, number of application programs, operating conditions etc., the waveform synthesizing 
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program is executed as one of the applications (1) to (n). Upon power-on or reset of the musical sound generator, as 
shown in Figure 7, various registers and flags are set/reset for initialization in step S1 . In step S2, system administration 
process of the OS is executed. In steps S3 to S5, the application program (1), the waveform synthesizing program, and 
the application program (n) are respectively executed. The waveform synthesizing program is executed to generate one 
s sample value of the wave data at one cycle of the program invocation. The application programs (1) to (n) do not include 
the waveform synthesizing program. These application programs may be related to music performance, or to entirely 
. different affairs. After step S5, the procedure returns to S2. 

If there is no change in execution status of the application programs, the loop of S2 to S5 is repeatedly executed. 
Otherwise, if there is a change in the execution status of the application programs, such a change is detected at the 
10 system administration process in step S2. If the change of the status is of program termination, the relevant execution 
step of the application program is skipped. If the change of the status is of program invocation, a step to execute a new 
application program is'added in the loop, and the whole loop is executed repeatedly. Thus, the executing period of the 
loop changes dependently on the running situation of the application programs and the system load. However, regard- 
less of the running situation of the application programs, one sample value of the wave data of the musical sound is 
1 s always generated per loop. A series of the sample values are generated continuously by repeating the loop to create a 
desired waveform. Thus, if the generated wave data is simply converted into an analog signal, the sampling period is 
varied, so that jitter may occur in the reproduced musical sound. The data buffer is provided before the D/A converter 
23 in order to temporarily store the generated wave data of the sound. The data buffer is accessed for readout of the 
wave data at a fixed sampling frequency fs. If the musical sound generation is conducted by a fixed program in a certain 
so case where the system is not a personal computer but a stand-alone electronic musical instrument, sound source mod- 
ule, or any other systems having a facility to generate sound, the execution period of the loop process can be fixed. In 
other words, the loop process is executed at a fixed interval . in such a case, it is very practical to make th e loop interval 
to coincide with the reciprocal of the sampling frequency fs so that the data buffer can be eliminated. 
. The waveform synthesizing program executed in step S4 is described hereunder referring to Figures 8 to 1 1 . The 
25 program is executed after loading thereof from the storage unit 1 5 according to a predetermined operation. In step Sa1 , 
the synthesizing mode and the hardware setup afe checked. In the hardware setup check, optional devices are recog- 
nized by the check method described before. As for the operating mode, both of the synthesizing mode and the voice 
allocation mode are checked as well. With respect to the operating mode setup, if other application programs are exe- 
cuted before invoking the waveform synthesizing program, the voice allocation mode may be turned to the compulsory 
30 mode. Otherwise, the synthesizing mode and the voice allocation mode may be set up according to the user choice via 
a displayed menu to input desired settings. Further, if various sound source devices are recognized in the hardware 
check, it is possible to set either of the CPU select mode or the sound source select mode. Thus, in the operating mode 
setup in step Sa1 , the operating mode is set up and recognized before executing the waveform synthesizing program. 
In step Sa2, waveform loading process is executed. In the waveform loading process, typical or basic waveforms 
3B are loaded into the area WAVE allocated in the RAM 1 3 or 20 in case that the basic waveform is used in the waveform 
memory readout mode. In step Sa3, it is tested whether a flag SETFLG is "1 " or not. The flag SETFLO is initially set to 
"0", but may be turned to "1" if the sampling frequency fs is set up in step Sa2l , or if the waveform memory readout 
mode is designated in a backup waveform computation mode. The procedure advances forward to step Sa4 if the flag 
SETFLG is "1". Otherwise, if the flag SETFLG Is "0", the procedure jumps to step Sa5. In case that the waveform syn- 
40 thesizing program is executed in the loop shown in Figure 7 at the first time, the flag SETFLG is "0", and the procedure 
unconditionally advances forward to step Sa5. However, the process of step Sa4 is also described here, for conven- 
ience of description. In step Sa4, it is tested whether the sound synthesizing should be carried out entirely by the CPU 
synthesizing mode or not. It is possible to use the result of the hardware check in step Sa1 to detect whether any exter- 
nal sound source device is recognized or not. If there is possibility of using any sound source other than CPU for the 
45 waveform synthesizing, step Sa4 branches to "No" direction, in step Sa5, a flag ENBLFLG is tested if it is "1 " or not, in 
order to detect a nonoperable state. The nonoperable state means that the sampling frequency fs is neither set up in 
the waveform generation procedure, nor the backup waveform computation mode is enabled. Therefore, the CPU syn- 
thesizing mode is not yet ready in the nonoperable state. 

When the waveform synthesizing program is executed in the main loop shown in Figure 7 at the first time, the flag 
so ENBLFLG is "0" so that the procedure advances forward to step Sal 1 . However, the process under an operable state 
in case that thefiag ENBLFLG is "1" is described here just for convenience of description. The operable state means 
that ail the preparation for the CPU synthesizing is already compieted. In this state, the procedure advances forward to 
step Sa6, where processing of performance information is done. In step Sa7, existence of a CPU waveform generation 
command is checked. The CPU waveform generation command is generated in response to a key-on event contained 
55 in the keyboard information KBD, MIDI information or performance information fed from the l/F under the CPU synthe- 
sizing mode. If the CPU waveform generation command is detected in step Sa7, the procedure responsive to the com- 
mand is executed in step Sa8. In the procedure of step Sa8, the wave data is generated by a specific synthesizing mode 
selected out of the available CPU synthesizing modes. The wave data is then distributed to the D/A converter 23 via the 
bus 12. Thus, the sound generation is accomplished according to the synthesized wave data or waveform. 
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In broader definition, the CPU waveform generation command may include a key-off event commanding note-off, 
though explanation for the procedures relevant to the key-off event is omitted here. These note-off procedures are very 
simple process such as release of the waveform generation and termination of the waveform generation. If no CPU 
waveform generation command is detected in step Sa7, the waveform synthesizing computation in step Sa8 is skipped, 

s since there is no job to be executed. In step Sa9, it is tested whether terminating operation of the waveform synthesizing 
program is conducted by the user or not. If the termination of the program is not indicated, the procedure immediately 
returns to prepare for a next CPU waveform generation command. On the other hand, in case that the termination com- 
mand is inputted, the waveform synthesizing program is terminated by setting the flag SETFLG to "0" in step Sa10. 
If the waveform synthesizing program is executed at the first time in the main loop of Figure 7, the flag ENBLFLG 

10 is "0". Then, in step Sa11, it is tested whether the allocation mode is either of the CPU select mode and the sound 
source select mode. If the allocation mode is the manual mode or compulsory mode, the detection result is "No" so that 
the procedure advances forward to step Sa12. where the flags ENBLFLG, DACENBL, and SETFLG are all set to "1". 
Then, the procedure returns. The flag DACENBL is set to "1 " to enable the D/A converter 23. Thus, if the waveform syn- 
thesizing program is executed next time and the external sound source is used, the check of step Sa3 results in "Yes" 

is and the check of step Sa4 results in "No" so that the procedure shown in Figure 1 1 is executed, Otherwise steps Sa6 
to Sa10 are executed if the waveform synthesizing is effected by only the CPU. 

On the other hand, when it is detected that the allocation mode is either of the CPU or sound source select mode 
in step Sa1 1 , the procedure advances forward to step Sat 3. The processing in steps Sa1 3 to Sa27 shown in Figures 
9 and 1 0 may be done if the waveform generation program is invoked at the first time. In this process, the sampling fre- 

20 quencyfs is determined for synthesis only by the CPU. In step Sal 3, the flag ENBLFLG is switched to "0", a flag BUSY 
is set to "1 ", and theflag DACENBL is set to "0" explicitly, the flag BUSY is set to "1 " to enable counting up In timer proc- 
ess described later. Setting of the flag DACENBL to "0" is done in order to disable the output operation of the D/A con- 
verter 23 to prevent sound generation during the trial waveform computation described later. After step Sal3, registers 
SCOUNT and TCOUNT are reset to "0". The content of the register SCOUNT indicates loop cycles of the following trial 

25 waveform computation. The register TCOUNT incrementally counts up while the flag BUSY is switched to "1 ". Thus, this 
register indicates a lapse time required to generate one waveform by m cycles of the synthesis computation. In step 
Sa15, one sample value for one sampling period is generated by the execution of a predetermined wave data genera- 
tion algorithm. The detail of the processing in step Sa15 will be described later. In step Sa16, the register SCOUNT is 
incremented by "1" whenever the sample value computation is executed once, fn step Sa17, it is tested if the register 

so SCOUNT reaches cycle "m". If it is detected NO, the procedure returns to step Sa1S. Otherwise, the procedure 
advances forward to step Sal8 in Figure 10 in case that the check result is YES. Thus, the steps Sa15 and Sa16 are 
repeated until the loop cycle of the sample value computation reaches to "m". 

In step Sa18 of Figure 10, the flag BUSY is switched to "0" to disable the counting up of the timer. Then, in step 
Sa19, a frequency Fs is calculated by the following equation (1). 

35 

Fs-(m-margin)/(TCOUNT-Tt) (1) 

In this equation, the "margin" is a constant set smaller than value 1 to provide the computation devices including the 
CPU 10 with some margin, considering the processing power of the devices. As described before, TCOUNT indicates 

40 invocation times of the timer during the period required to "m" cycles of the execution of the sample value calculation, 
while Tt indicates a pitch of the timer. Thus, the product of TCOUNT and Tt corresponds to the period required for com- 
pleting the sample value calculation process to generate one waveform. 

Thus, the frequency Fs calculated by the equation (1) is the frequency of the waveform sampling, and the constant 
"margin" reflects the processing power of the hardware setup. 

45 In step Sa20, it is detected whether the calculated frequency Fs is greater than 32 kHz or not. This critical fre- 
quency "32 kHz" is employed considering the minimum quality of the musical sound to be generated. If this detection 
result is positive, which means that the processing power of the CPU is evaluated as sufficient for maintaining the min- 
imum quality of the sound, the procedure advances forward to step Sa2l. In step Sa21, an adequate sampling fre- 
quency fs smaller than and closest to the calculated frequency Fs is selected out of 32 kHz, 44.1 kHz, 48 kHz, and 50 

so kHz. If the calculated frequency Fs is 47 kHz, the sampling frequency fs is set to 44.1 kHz, which is closest to and 
smaller than 47 kHz. The value smaller than the calculated frequency Fs is selected because the constant margin does 
not make sense if the sampling frequency fs is set to exceed the processing power of the CPU. After step Sa21 , the 
flags DACENBL, ENBLFLG and SETFLAG are all set to "1 " in step Sa22, and the procedure returns. This flag operation 
enables the D/A converter 23 to output the musical sound. Further, this flag operation indicates that the sampling fre- 

55 quency fs is set up. Consequently, the nonoperable state is changed to the operable state. 

Under the operable state, upon the next execution of the waveform synthesizing program, check of step Sa4 results 
in "No" so that the synthesizing is done by the processing shown in Figure 1 1 if the waveform synthesizing should be 
carried out by the external sound source device. Otherwise, if only the CPU is used for the waveform synthesizing, 
check of step Sa4 results in "Yes" and check of step Sa5 results in "No" so that the synthesizing is carried out through 
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steps Sa6 to Sa8. 

On the other hand, in Figure 10, if the result of the test about the calculated frequency Fs in step Sa20 is turned 
out W, which means that the minimum quality of the sound cannot be retained, the procedure advances forward to 
step Sa23. In the step Sa23, the user is warned that the minimum quality of the sound is not available, and the backup 

s waveform computation mode is called. The backup waveform computation mode is the waveform memory readout 
mode which is selected as a secondary choice when the minimum quality of the sound is not affordable with the primary 
synthesizing mode selected out of the available CPU synthesizing modes. In step Sa24, it is tested whether the backup 
waveform computatio'n mode is designated or not. If YES, the procedure goes forward to step Sa25, where original 
waveforms are prepared by the primary computation mode and are stored in the RAM 13 or 20 in advance. Further, the 

10 sound is actually reproduced when the stored waveform is read out at the sampling frequency 32 kHz, which is auto- 
matically determined. Thus, the waveform synthesizing is effected virtually with the waveform memory readout mode, 
so that the minimum quality of the reproduced sound can be retained even if the low performance CPU is equipped in 
the system. After that, the process in step Sa22 is executed to switch the nonoperable state to the operable state, and 
the procedure returns. On the other hand, if the backup waveform calculating mode is not specified in step Sa24, the 

is procedure goes forward to step Sa26, in which a termination command for the sound synthesizing program is detected. 
If the termination of the sound synthesizing program is commanded, the operation finishes, by clearing the flag SET- 
FLG to "0" in step Sa27. In case that the calculated frequency Fs is smaller than 32 kHz, and the backup waveform cal- 
culation mode is neither specified nor the program termination is commanded, the warning alarm is continued. Thus, 
the waveform synthesizing is done with the computation devices such as the CPU 1 0. The sampling frequency fs is opti- 

so mized with respect to the CPU performance. Further, if the performance of the CPU is low, the synthesizing is executed 
by switching to the waveform memory readout mode, which can reduce the CPU load. 

For summary, the CPU-aided second waveform generator comprises a computerized waveform generator operable 
according to a given algorithm at a variable operation speed to create a digital waveform by successively computing 
sample values of the digital waveform. The computerized waveform generator is provisionally operated to carry out trial 

25 creation of a model digital waveform while measuring the operation speed at which the trial creation is carried out. The 
sampling frequency is optimally determined in comparable to the measured operation speed. The computerized wave- 
form generator is actually operated to enable the same to successively compute sample values of an actual digital 
waveform at the determined sampling frequency according to the provided performance information. The sample fre- 
quency is fixed to one of stepwise predetermined levels, which is lower than and closest to the measured operation 

30 speed. When the determined sampling frequency falls below a critical level which is defined to ensure a minimal quality 
of the digital waveform, the initial algorithm is changed to raise the operation speed of the computerized waveform gen- 
erator so that the sampling frequency can be redetermined to exceed the critical level, the algorithm is changed from 
a complicated one to a simplified one such that the computerized waveform generator operates based on the simplified 
one of the algorithm to successively read out prestored ones of sample values to reproductively create the digital wave- 
as form. The sample values may be initially computed by the complicated algorithm. Then, the sample values are stored 
in the waveform memory for actual use under the simple algorithm of the waveform memory readout mode. Thus, the 
inventive sound generating apparatus for creating a digital waveform to generate a musical sound according to perform- 
ance information, comprises input means for providing performance information, computerized waveform generator 
means operable based on a given algorithm at a variable operation speed to create a digital waveform by successively 

40 computing sample values of the digital waveform, triai means for provisionally operating the computerized waveform 
generator to carry out trial creation of a mode! digital waveform while measuring the operation speed at which the trial 
creation is carried out, determining means for optimally determining a sampling frequency comparable to the measured 
operation speed, controller means for actually operating t(ie computerized waveform generator to enable the same to 
successively compute sample values of an actual digital waveform at the determined sampling frequency, and output 

45 means for generating the musical sound based on the actual digital waveform according to the provided performance 
information. 

By the way, if there is detected a possible use of the hardware sound source device for the waveform synthesizing 
in step Sa4 in Figure 8, the procedure branches to step Sa28 in Figure 1 1 . In step Sa28, the flag DACENBL is switched 
to "1" to enable the D/A converter 23 to output the sound. In step Sa2S, any termination command for the sound syn- 

so thesizing program is detected. If the termination of the sound synthesizing program is commanded, the synthesizing 
program finishes by clearing the flag SETFLQ to "0" in step Sa31 through step Sa30. On the other hand, if the termina- 
tion of the sound synthesizing program is not commanded, the operating mode is checked whether it is the sound 
source synthesizing mode or not in step Sa32, if the detection result of step Sa29 is negative. When the sound source 
synthesizing mode is detected in step Sa32, existence of the hardware required for the specified mode is detected in 

55 step Sa33. This mode is specified upon the recognition with the hardware check in step Sa1 . If the relevant hardware 
exists, the synthesizing procedure is executed by the relevant hardware in step Sa34. Otherwise, the lack of the relevant 
hardware is issued instep Sa35, and the synthesizing process is continued using the current hardware setup, if the rel- 
evant hardware does not exist. After steps Sa34 and Sa35, the procedure returns. The synthesizing processing with the 
selected hardware wiil be described later. 
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The waveform loading process executed in step Sa2 (Figure 8) will be described hereunder with reference to Figure 
12. In the waveform loading process, it is detected whether a MIDI sample dump command is received through the multi 
I/O port 14 in step Sb1 . The MIDI sample dump contains a wave data according lo the MIDI standard, and is used in 
the waveform memory readout mode. If the MIDI sample dump is received, the sample receiving procedure- is con- 
s ducted such that the received data is transferred to the area WAVE in RAM 1 3 or 20 in step Sb2. The sample dump 
receiving of step Sb2 is repeated until all of the data reception are completed. The completion is detected in step Sb3. 
If all of the data reception are completed, the detection in step Sb3 results in "Yes", and the procedure returns. On the 
other hand, if the check of step Sbt results in "No", it is checked if the wave data is transferred via the interface 1/F in 
step Sb4. If the wave data is received, the received data is transferred to the area WAVE in the RAM 13 or 20 in steps 
io~ Sb2 and Sb3, as in the case of the MIDi sample dump, if both the steps Sb1 -and Sb4 result in "No", art access reading 
event for the storage unit 15, namely the request to read out some; data from the storage unit 15, is detected in step 
Sb5. If the request is not issued, the waveform loading is terminated immediately and the procedure returns, since there 
is no more job to do. On the other hand, when the access event occurs, the data read out from the storage unit 15 is 
checked in step Sb6. Further, in step Sb7, it is tested whether the read out data is the wave data or not; If the read out 
is data is not the wave data, the waveform loading is terminated immediately and the procedure returns, since there is no 
more job to do. Otherwise, if the wave data is read out, the wave data is transferred to the area WAVE in the RAM 13 
or 20. The data transfer in step Sb8 is repeated until the end of the data transfer is detected in step Sb9. When the data 
transfer is completed, the check of step Sb9 results in "Yes" and the procedure returns; Thus, in the waveform loading, 
the wave data to be used in the waveform memory readout mode is received or read out. Then, the wave data is trans- 
20 ferred to the area WAVE in the RAf\1 13 or 20. ftie computation devices such as CPU 10 process the wave data with 
the waveform memory readout mode according to a simple algorithm in order to synthesize the actual waveform. In 
order to reproduce the wave data .loaded in the RAM 1 3 or 20 by the sound source 22, the loaded basic wave data might 
be transferred again to the waveform memory 25 included in the sound source 22. In a conventional musical sound gen- 
erator having a specific hardware sound source, the hardware sound source must have a temporary waveform memory 
25 to receive the loaded wave data. The CP U must execute the wave data transfer from the RAM to the waveform memory. 
However, in the present embodiment, the basic wave data is loaded to RAM 13 or 20 under the control of the CPU 10. 
Therefore, it is not necessary to provide the temporary memory to hold the wave data in the hardware. Further, it is not 
necessary to execute re-loading process in which the loaded wave data is transferred further to the external hardware 
device. The costs for the system hardware or software can be reduced, and the time from the end of the wave data load- 
so ing to the reproduction of the sound can be shortened. 

The sample value computing operation executed in step Sa15 {Figure 9) will be explained hereunder with reference 
to Figure 13. In step Sc1 of Figure 13, it is tested whether the co-processor 17 exists. In the present embodiment, the 
co-processor 1 7 is installed. However, this device is optional and may be lacked in some hardware setup. If the CPU 1 0 
accommodates an arithmetic operation unit equivalent to the co-prbcessor 1 7, the detection of the co-processor is not 
35 required. It is possible to regard the system as if! the co-processor is installed. If the co-processor 1 7 is detected, the 
sample value calculation is done with the CPU 10 as well as the co-processor 1 7 in step Sc2. Otherwise, the sample 
value calculation Is carried out only with the CPU 10 in step Sc3, if there is no co-processor 1 7. After step Sc2 or Sc3, 
the procedure returns. The sample value calculation is the same in steps Sc2 and Sc3, except that the co-processor 1 7 
is used or not. Thus, the detail of the sample value'calculatjon is explained with respect to step Sc3 here. 
40 In step Sd1 of Figure 1 4, it is tested whether the : current operating mode is set to the FM mode among the various 
CPU synthesizing modes. If the FM mode is set, "a set of sample values corresponding to a number of channels are 
calculated at one sampling point according to the FM synthesizing method in step Sd2. For example, if polyphonic syn- 
thesizing is selected, a set of multiple sample values required for synthesizing a desired number of voices are calcu- 
lated. In this case, the load of the CPU 10 is high, since ; various voices- having various pitches may be concurrently 
4S created. Even worse, other processing such as graphics processing may be done in parallel. If the FM mode is not 
detected in step Sd1, it is detected whether the current operating mode is set to the waveform memory readout mode 
among the CPU synthesizing modes in step Sd3 : If the waveform memory readout mode is detected here, a set of sam- 
ple values required for one sampling point are read out from the waveform memory. In polyphonic synthesizing, multiple 
samples required for synthesizing a desired number of voices are read out. This data reading and data transfer is not 
so carried out by the CPU 10, but by the DMAC 19. The wave data has been loaded to the area WAVE in the RAM 13 or 
20, or provisionally stored in the ROM 11. If the waveform memory readout mode is not detected in step Sd3, it is 
detected whether the current operating mode is set to the harmonics synthesizing mode among the various CPU syn- 
thesizing modes in step Sd5. If the harmonics synthesizing mode' is detected, a set of sample values required for one 
sampling process are calculated by the CPU 10Taccording'to the harmonics synthesizing method in step Sd6. In poly- 
55 phonic mode, a number of samples required for: Synthesizing a desired number of voices are calculated with the har- 
monics synthesizing method. In this case, the Idad of the CPU 10 is high, since various voices having various pitches 
may be created concurrently. Even worse, other processings may be carried out in parallel, similarly to the situation 
under the FM mode. If the harmonics synthesizing method is not detected in step Sd5, it is tested whether the current 
operating mode is set to the physical model synthesizing mode among the various CPU synthesizing modes in step 
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Sd7. If the physical model synthesizing mode is detected, samples required for one sampling point are calculated by 
the CPU 10 according to the physical model synthesizing method in step Sd8. In polyphonic mode, a number of sam- 
ples required for synthesizing a desired number of voices are calculated with the physical model synthesizing method. 
If the physical model synthesizing mode is not detected in step Sd7, the current operating mode is out of the present 
5 embodiment, so that the warning for the wrong mode setting is executed in step Sd9 as well as other process. After 
steps Sd2, Sd4, Sd6, Sd8, or Sd9, the procedure returns, and then the following step Sa16 (Figure 9) is executed. 

As for the waveform sample value calculation with the CPU 10 and the co-processor 17executed in the step Sc2, 
the procedure shown in Figure 14 is executed with cooperation of the CPU 10 and the co-processor 17 so that the cal- 
culating operation can be made faster. The detailed explanation for the Operation is omitted here, since the procedure 
10 is basically the same as the calculation only by the CPU 

Thus, in the waveform sample value calculation in step Sa15, the most influential processing on the quality of the 
synthesized sound is carried out by one of the CPU synthesizing modes. In the FM, harmonics synthesizing, or physical 
model synthesizing mode, the time required for the wave data calculation ■ as well as the number of voices to be repro- 
duced simultaneously, is the bottle neck of the sound synthesizing. The wave data at each sample point is actually cal- 
15 culated in order to examine the processing power., the calculation is repeatedly done in steps Sa15 to Sa17 for m 
cycles, and the time required for the m sample calculation is measured by the timer operation to set the sampling fre- 
quency fs suitable for the processing power of the CPU in step Sa21 . Similarly in the waveform memory readout mode, 
the readout operation of the wave data is the bottle jheeit of the sound synthesizing, so that the wave data at each sam- 
ple point is read out to examine the accessing speed. The readout process is done in steps Sa15 to Sa17 for m sam- 
so pies, and the time required for the m sample calculation is measured by the timer operation to set the sampling 
frequency fs suitable for the processing power of the CPU in step Sa21 . , 

The synthesizing by the selected hardware, which is executed in the above-described step Sa34 (Figure 11), is 
explained hereunder. This synthesizing process is effected unless voices of altlhe channels are synthesized by the 
CPU synthesizing mode alone.. This process is executed to control the sound source device used for synthesizing the 
25 waveform according to the allocation mode. Firstof all. in this,. procedure,., event detection, is carried out in step Se1 of 
Figure 1 5. The event includes a kieyon event issued in response to keyboard information KBD or MIDI information, and 
includes other events not only associated to the CPU synthesizing mode, but also associated to the sound source 
device mode. Upon detecting the key-on event, the apparatus initiates the synthesizing process. In step Se2, it is tested 
whether the current operating mode designates the sound source synthesizing mode or not. If the detection result is 
30 "No", the procedure branches to step Se1 1 . Otherwise, the procedure goes forward to following step Se3, if the detec- 
tion result is "Yes". In step Se3, it is tested whether the current synthesizing' operation status of the sound source 
devices and the performance information; corresponding to the event comply with a "condition" for synthesis of wave- 
form by the sound source device. In the present embodiment, One condition is whether the number of voices (timbres) 
to be synthesized currently is within a maximum number of voices which can be synthesized simultaneously by the 
35 hardware device specified in the sound source syht^i^g mode. More p||tictfari,initep Se3, the number of chan- 
nels currently being in active status and being allbaated*for thy sound, soarce'device is less than or equal to the full 
number of the. channels which can be used for simlFfeflSous synthesis oWoicls By trie* device. The "condition" may 
include other factors listed hereunder: (1) Whether ^plp" or a "touch" Ipecfed'by the detected event is higher (or 
lower) than a predetermined value. (2) Whether a value relevant to "timbre" specified by the delected event is higher (or 
■to lower) than a predetermined value. (3) Whether a value relevant to a number of "parts" in the performance information 
specified by the detected event is higher (or lower) than a predetermined value. (4) Whether a detected MIDI-CH value 
(number of channels) relevant to the detected event is higher (or lower) than a predetermined value. As shown above, 
the criteria for the "condition" may be generalized as whether a certain value specified by the performance information 
is higher (or lower) than a predetermined value. It is possible to implement a particular "condition" to issue a negative 
45 result if some unique timbre is specified to be synthesized |n the FM mode or the harmonics synthesizing mode using 
the sound source device. This implementation will (^djfpribed later in a|phjkeitfbo3j'ment. If the "condition" is ful- 
filled, channel assignment process is conducted ih«tep»Be4 such that a channel to synthesize a voice for the key-on 
event is allocated out of vacant channels. in the souflB'soTSrce device, which ar§ currently not used for synthesizing the 
sound. In step Se5, the sound generation is: exe'cuifsLii|hg the specified IfcunB source hardware, in which the actual 
so synthesizing of the waveform is done IbMhe! tesuedreventfn th$ aJtacated channel. • 

If the "condition" is not fulfilled in step Se3, Itis^sfWwhether the fla^Er^LPEG 1eT"1 " or not in step Se6. In this 
stage, the value "1" of the flag ENBLFL0 indicates f$gi lie steps Sal3 toSa2'£have been executed already, and indi- 
cates that the sampling frequency fs tot; the CPU synthesizing mode is already set up; Thus, the CPU synthesizing 
mode is available. Therefore, if the test result of ste^e^ "Yes" because^f value "1" dl.the flag ENBLFLG, voice allo- 
55 cation procedure to the CPU synthesizing mode is executed in step Se7 so-thatthe synthesizing of the waveform rele- 
vant to the event which does not comply with the c^fttGn for synthesizing bft>e"eoufiel source device is carried out 
by the CPU synthesizing mode. Particularly, an all&tiSH command is issued to calculate sample values of the wave- 
form relevant to the event in this CPU synthesizing allocation procedure. The command includes designation of com- 
putation mode to be executed by the CPU 10 (any mode out 0} the CPU synthesizing modes), and designation of the 
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timbre, pitch, touch, volume and channel assignment. Further, the command includes note commands such as key-on 
or key-off. During the allocation command is valid, the computation devices including the CPU 10 execute the waveform 
synthesizing computation process in order to generate the sample values relevant to the event in step Seio. The allo- 
cation command also includes information about the start and end of interrupts, if the waveform is generated with the 

s interrupt process. On the other hand, if the value "0" of flag ENBLFLG is detected in step Se6, the CPU synthesizing 
mode is not available. In this case, truncating process is carried out to turn off sound reproduction operation of a chan- 
nel which is the oldest in step Se8. to make a vacant channel forcibly. This truncating process may be included in the 
allocation process executed in step Se4. In step Se4, the relevant event is allocated to the vacant channel made by the 
forcible note-off, and the synthesizing of the waveform relevant to the event is carried out by the allocated channel in 

io step Se4. If multiple sound source devices are installed to the system, channels of the different sound source devices 
may be allocated to synthesize a single timbre. 

By the way, if the sound source device select mode or preceding mode is not detected in step Se2, there may be 
the CPU select preceding mode or the manual mode in which the CPU synthesizing mode is set together with the sound 
source synthesizing mode. Thus, the procedure branches to step Se11 in Figure 16. In this step Se11, it is tested 

15 whether the current state of the CPU synthesizing mode and the performance information relevant to the issued event 
comply with the "condition" for synthesizing by the devices including the CPU. Various factors may be conceived as the 
"condition" for synthesis by CPU as in the case of the "condition" for synthesis by the sound source device {step Se3). 
In this embodiment, the condition is whether a number of voices (timbres) to be synthesized currently is wilhin a maxi- 
mum number of voices which can be synthesized simultaneously with the CPU synthesizing mode. More particularly, 

so in step Se1 1 , it is tested whether the number of channels (CH) currently being held in note-on status and being allo- 
cated for the computation devices including the CPU is less than or equal to the maximum number of the channels 
which can be used for simultaneous synthesizing of the waveforms by the CPU synthesizing mode. If the "condition" is 
satisfied, it is tested whether the flag ENBLFLG is "1 " or not in step Se12. As described above, the value "1" of the flag 
ENBLFLQ here indicates that the synthesis of the waveform by the CPU synthesizing mode is ready to be started. 

25 Therefore, the allocation procedure is executed for the waveform synthesis by the devices including the CPU 10 in step 
Se13, and the procedure further goes forward to step Se9. The detail of the allocation procedure in step Se13 is not 
explained here again, since the procedure is eventually the same as in step Se7. On the other hand, if the "condition" 
for synthesis of the waveform by CPU is not complied in step Se1 1, or the devices including the CPU 1 0 are not ready 
in step Se12, the allocation procedure is executed in step SeH as in step Se4, so that the processing relevant to the 

30 event is done by the external sound source device. The synthesizing using the specified hardware is done in step Se1 5 
as in step Se5. After step Se13, steps Se9 and step Se10 are executed. In step Se9, it is detected whether the alloca- 
tion command exists to generate wave data by the CPU. tf the command is not detected, the procedure returns imme- 
diately. Otherwise, the waveform is calculated according to the allocation command to generate sound by the CPU in 
stepSelO. 

35 Thus, in the external sound source select preceding mode, the synthesizing process complying with the "condition" 
for synthesis by the hardware device is executed by the sound source in step Se5, white the synthesizing process which 
does not comply with the "condition" is executed by the CPU 1 0 in step Se1 0. On the other hand, if the designated mode 
is not the sound source preceding select mode, the process complying with the "condition" for synthesis by the CPU 10 
is executed by the software module in step Se10, while the synthesizing process which does not comply with the "con- 

4o dition" for synthesis by the CPU is executed by the hardware sound source device in step Se1 5. Thus, in the synthesis 
using the selected hardware, if the synthesizing process exceeds the processing power of the hardware specified in the 
sound source synthesizing mode, the exceeding part of the process is executed by the CPU synthesizing mode, so that 
it is possible to synthesize a plurality of voices more than the full number of voices which can be simultaneously repro- 
duced in the hardware without enhancing hardware setup. In general, when the input device such as the I/0 1 4 provides 

45 performance information effective to command concurrent generation of a plurality of musical sounds, the inventive 
apparatus designates one of the first waveform generator and the second waveform generator according to a number 
of concurrent musical sounds specified by the performance information such that the designated one has a capacity 
sufficient to create a number of waveforms corresponding to the number of the musical sounds. When the number of 
the concurrent musical sounds exceeds a capacity of either of the first waveform generator and the second waveform 

so generator, both of the first waveform generator and the second waveform generator are designated to ensure complete 
generation of the concurrent musical sounds. 

The timer process will be described hereunder. The timer process is an interrupt process executed at a predeter- 
mined interval Tt during the trial waveform synthesis program described before. Figure 1 7 is a flowchart illustrating the 
timer process in detail. In step Sf1 , it is tested if the flag BUSY is "1", which means that the counting up of the timer is 

55 enabled. If this detection results in negative, the procedure skips to Sf3. Otherwise, the routine goes forward to step Sf 2, 
where the register TCOUNT is incremented by "1" if the detection result is positive. In step Sf3, other miscellaneous 
timer processes are executed to finish the timer routine. Thus, the timer process increments the register TCOUNT by 
"1 " if the flag BUSY is "1 ". The flag BUSY switches to "1 " only in the loop of steps Sa9 to Sa1 1 so that the content of 
the register TCOUNT indicates the invocation cycles of the timer process within the time required for the computation 
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or reading of one waveform. The lapse time can be derived by multiplying TCOUNT by Tt. 

In the arrangement shown in Figure 1, all the optional devices such as the co-processor 17, DSP 21 and external 
sound source 22 are fully installed. Thus, in this arrangement, all the operating modes can be designated with respect 
to the i synthesizing mode and the allocation mode. If the operating mode is set to the sound source select mode atfirst 
S, ™ ?u J? ' 1 pr0C6SS ex08 * din 0 the Pressing power of the external sound source is allocated to the CPU, and 
the CPU handles the process so that the musical sound can be generated beyond the limitation of the external sound 
source dev.ce. and various timbres can be generated. Further, various timbres can be generated also in the CPU select 
mode given first priority. Since the sampling frequency fs is always set to the optimum value at step Sa21 the quality of 
the generated sound can be maintained high. 

in the embodiment described above, the optional devices are fully installed as shown in Figure 1. However the 
hardware setup of the personal computer or the electronic musical instrument varies depending on which optional 
device ts installed. The available operating mode of the musical sound synthesizing program is different depending on 
the hardware setup. The operations of the musical sound synthesizing program in other hardware arrangements which 
are different from that in Figure 1 will be described hereunder. 

The hardware setup shown in Rgure 21 lacks all the optional devices including the co-processor 1 7, DSP 21 and 
LSI sound source 22. Of course, the sound source synthesis mode is not available in this setup, because the detection 
in step Sa4 (Figure 8) becomes "Yes", and only the CPU synthesizing mode can be utilized. However, if the processing 
power of the CPU 1 0 is not very high enough, the real-time wave data computation is impossible, since both of the co- 
processor 17 and DSP 21 are not installed. Thus, there may be a situation in which the waveform memory readout 
mode is only available in the CPU synthesizing modes. 

The hardware setup shown in Figure 22 has only the co-processor 1 7 as an optional device. In this setup, the hard- 
ware sound source synthesis mode is not affordable, because the detection in step Sa4 (Figure 8) becomes "Yes" The 
CPU synthesizing mode is only available. However, all the CPU synthesizing modes are possible, because high speed 
real time arithmetic operations are possible by the co-processor 17. The actual waveform calculation (step Sa9), as well 
as the trial waveform calculation (step Sal5), is executed by both of the CPU 10 and the co-processor 17 in this setup 
since the co-processor 17 is available. 

Thetordware setup shown in Figure 23 includes the co-processor 17 and the DSP 21 as optional devices. The pur- 
pose of the DSP 21 is to ensure high speed calculation of the wave data. If the DSP 21 is treated as the external sound 
source, the sound source synthesis mode is available by means of the DSP on the, second invocation of the synthesiz- 
ing program or thereafter, since the detection in step Sa4 (Figure 8} becomes "No". However, the purpose of the DSP 
21 is to facilitate data calculation, so that the wave data is not generated by the waveform memory readout method, but 
is generated by the various pure arithmetic modes such as FM mode, harmonics synthesis mode and physical mode- 
ling mode. Further, the CPU synthesizing mode is available depending on the allocation mode. The wave data calcula- 
tion is possible, but the waveform memory readout mode is not available since the DM AC 1 9 and RAM 20 are deleted. 
It is possible to utilize only the FM mode, harmonics synthesizing mode, and physical model synthesizing mode, where 
the real-time high speed wave data calculation is executed. The actual waveform calculation (step Sa8), as well as the 
trial waveform calculation (step Sal5), is executed by both of the CPU 1 0 and the co-processor 1 7 in this setup. 

The hardware setup shown in Figure 24 includes only the LSI sound source 22 as an optional device. In this setup, 
the sound source synthesis mode is available on the second invocation of the synthesizing program or thereafter, since 
the detection in step Sa4 (Figure 8) becomes "No". Further, the CPU synthesizing mode is available depending on the 
allocation mode. However, there may be a situation in which the waveform memory readout mode cannot be utilized, 
since DMAC 1 9 and RAM 20 are missing. Further, if the processing power of the CPU 1 0 is not very high enough, the 
real-time wave data calculation is impossible since the co-processor 1 7 lacks. Thus, there may be a situation in which 
all the CPU synthesizing modes are not available. 

A second embodiment will be explained hereunder. Generally, it is difficult to reproduce the realistic sound of the 
percussive tones such as a rhythm or drum instrument by the wave data computation according to FM mode or harmon- 
ics synthesizing method. Thus, if the LSI sound source 22 is installed and this sound source 22 calculates the wave 
data of the musical sound by the pure calculating method such as FM mode other than the waveform memory readout 
mode, it is not adequate to reproduce the sound by the LSI sound source 22. Further, it is not necessary to calculate 
the wave data by the arithmetic calculating mode olher than the waveform memory readout mode by the CPU 1 0, if this 
sort of the LSI sound source 22 is installed. Further, the CPU 10 should execute jobs other than the waveform synthe- 
sizing, so that a system load required for the execution of the waveform synthesizing program should be reduced as 
much as possible, especially in case that the processing power of the CPU 10 is not high. Thus, in this situation, it is 
convenient that the CPU 1 0 generates the percussive wave data unsuitable for the LSI sound source 22 by the wave- 
form memory readout mode, while the LSI sound source 22 generates the wave data for other timbres. Thus, the com- 
putation load can be reduced for the CPU 10, and the LSI sound source 22 does not have to synthesize any wave data 
for which the sound source 22 has poor ability. The quality of the reproduced sound can be maintained high as much. 
The purpose of the second embodiment is directed to the very point. The second embodiment assumes that the sound 
source 22 is installed as shown in Figure i or 24. With respect to the waveform synthesizing program, the synthesizing 
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process using the selected hardware (Figures 15 and 16) Is replaced with the process shown in Figure 18. More par- 
ticularly, the synthesizing process using the selected hardware in step Sa34 (Figure 1 1) is substituted for the process 
shown in Figure 18. The substituted process will be described hereunder, while omitting the explanation of the other 
processes for avoiding duplicated description. 
5 In this second embodiment, upon advancing forward to step Sa34, the program runs to execute the synthesizing 
process using the selected hardware as shown in Figure 18. In step Sg1 , the event detection is carried out as in step 
Se1 . In step Sg2, system check for voice allocation is executed. More particularly, a device to handle the synthesis is 
determined far each voice (timbre) out of the CPU and the LSI sound source. The criteria for this allocation will be 
described hereunder. Generally, the sound source has unique disposition of available timbres, so that an individual tim- 
10 bre can be specified by a unique timbre code. Thus, it is possible to implement a table containing the list of the timbre 
codes of the percussive tones in advance, in order to discriminate between the tones to be handled by the CPU 10 in 
case that the timbre code detected for the relevant event is found in the table, and the other tones to be handled by the 
LSI sound source 22. However in the present embodiment, the allocation criteria may not be limited to the timbre code. 
It is posstole to setup timbre handling means under the manual mode, in such a manner that a certain timbre is to be 
is handled by the CPU, and another timbre is to be handled by the sound source. Each tone can also be allocated depend- 
ing upon tiie number of the channels which can be used for simultaneous synthesizing. Further, under a compulsory 
mode, each tone can be allocated forcibly by other running programs. 

For the tones allocated to the LSI sound source', vacant channels are created by the voice allocation process in step 
Sg3 as in step Se4 (Figure 15). In step Sg4, the waveform relevant to the key-on event is synthesized through the 
so vacant channels. The synthesizing method for this operation is not limited to the FM mode, the harmonics synthesizing 
mode or the physical modeling mode, but it is possible to use, for example, PCM mode to read out the wave data from 
the waveform memory 25, depending upon the characteristics of the installed sound source 22. On the other hand, for 
the timbres allocated to the CPU, the CPU synthesizing allocation procedure is done in order to generate an allocation 
command to generate wave data relevant to the detected event in step Sg5 as in step Se7 (Figure 1 5). If the allocation 
25 command is available, the detection in step Sg6 results in "Yes", and the synthesizing calculation in step Sg7 is exe- 
cuted to generate a waveform relevant to the allocation command. The synthesis of the waveform is effected by the 
waveform memory readout mode in order to reduce the load for the CPU as described before. On the other hand, when 
the allocation command is not available, the detection in step Sg6 results in "No", and the procedure returns. 

In this second embodiment, musical sounds can be allocated selectively to the CPU and the sound source accord- 
so ing to their timbres so that the optimum distribution of the processing load for the CPU and the sound source is possible, 
and the various timbres can be generated while retaining the quality of the reproduced sounds. For summary, the input 
device provides performance information which contains timbre information effective to specify a timbre of the musical 
sound and timing information effective to specify a timing of generation of the musical sound. One of the first waveform 
generator and the second waveform generator is designated in correspondence with the timbre information so that the 
35 output device generates the musical sound having the specified timbre at the specified timing. 

In the first and second embodiments, the synthesizing process for one tone is executed in the channels provided 
on the CPU or in the other channels provided in the sound source. However, the synthesizing process for a tone can be 
executed by both of the CPU and the sound source. In this arrangement, it is possible to use the harmonics synthesiz- 
ing mode in the CPU side, and to use a mode other than the harmonics synthesizing, e.g., the FM mode in the sound 
40 source side, so that variational tones can be generated because the same tone Is synthesized by the different calcula- 
tion modes. The purpose of a third embodiment is directed to the very point. In the third embodiment, the LSI sound 
source is assumed to be installed in the system as shown in Figures 1 and 24. With respect to the waveform synthesiz- 
ing program, the synthesizing process using the selected hardware device (Figures 15 and 16) is replaced with the 
process shown in Figure 1 9. More particularly, the synthesizing process using the selected hardware in step Sa34 (Fig- 
45 ure 1 1) is substituted for the process shown in Figure 19. The substituted process will be described hereunder, while 
omitting the explanation of the other processes for avoiding duplicated description. 

In this embodiment, upon advancing forward to step Sa34, the synthesizing program runs to execute the synthe- 
sizing process using the selected hardware as shown, in Figure 19. In step Sh1, the event detection is carried out as in 
steps Se1 and Sg1 . In step Sh2, system check for voice allocation is executed. More particularly, a device to handle the 
bo synthesis is determined for each voice (tone) out of the CPU and the LSI sound source. The criteria for this allocation 
may be the timbre code, number of channels available for simultaneous synthesizing, or the setup configured by the 
manual or compulsory mode, as in the second embodiment. For the tones allocated to the LSI sound source, vacant 
channels are prepared by the voice allocation process in step Sh3 as in step Se4 (Figure 1 5) . In step Sh4, the waveform 
relevant to the note-on event is synthesized through the vacant channels. The synthesizing method for this operation is 
55 not limited to the FM mode or the harmonics synthesizing method, but it is possible to use, for example, the physical 
modeling mode and the PCM mode to read out the wave data from the waveform memory 25 depending upon the char- 
acteristics of the installed sound source 22. On the other hand, for the tones allocated to the CPU, the CPU synthesiz- 
ing allocation procedure is done in order to generate an allocation command relevant to the detected note-on event in 
step Sh5 as in step Se7 (Figure 15). Information about the calculation method is included in the allocation command. 



EP 0 747 877 A2 



The voice allocated to both of the CPU and the sound source is processed in steps Sh3 and step Sh4 by the LSI sound 
source,, while trie same voice is processed in steps Sh5 by the CPU. These processes are executed in parallel. If the 
allocation command is available, the detection in step Sh6 results in "Yes", and the synthesizing calculation in step Sh7 
is executed to generate a waveform relevant to the allocation command. Unlike the second embodiment, the synthesiz- 
s ing calculation is done by various modes including the FM, harmonics synthesizing, physical modeling and so on. On 
the other hand, if the allocation command is not available, the detection in step Sh6 results in "No", and the procedure 
returns. 

In the third embodiment, a voice (tone) can be allocated to both of the CPU and the LSI sound source so that dif- 
ferent wave data can be reproduced for the same tone actually. Due to this feature, the third embodiment can also diver- 
jo sify the toned of the system. For summary, both of the first waveform generator and the second waveform generator are 
coincidently designated so that the controller device operates both of the first waveform generator and the second 
waveform generator to concurrently create waveforms in parallel manner for a single timbre. 

A fourth embodiment will be explained hereunder. Even though the voice allocation mode is introduced in the 
embodiments described above, more simple implementation is possible. An event which can be allocated to a certain 
is sound source device is simply allocated to the relevant device upon the event detection, provided that the device is 
installed in the system, The very implementation is provided in this fourth embodiment. The fourth embodiment 
assumes that the sound source 22 is installed as shown in Figure 1 or 24, as in the second and third embodiments. With 
respect to the waveform synthesizing program, the synthesizing process using the selected hardware device (Figures 
15 and 16) is replaced with the process shown in Figure 20. More particularly, the synthesizing process using the 
20 selected hardware device in step Sa34 (Figure 1 1) is substituted for the process shown in Figure 20, The substituted 
process will be described hereunder, while omitting the explanation of the other processes for avoiding duplicated 
description. 

In this embodiment, upon advancing forward to step Sa34, the synthesizing program runs to execute the synthe- 
sizing process using the selected hardware as shown in Figure 20. First of all, the event detection is carried out though 
ss this process is not illustrated. In step Si1, voice allocation is executed to create a vacant channel in the LSI sound 
source. In step Si2, the waveform relevant to the detected event is actually synthesized usihg the vacant channel. The 
synthesizing method for this operation is not limited to the FM mode or the harmonics synthesizing mode, but ft is pos- 
sible to use, for example, the physical modeling mode and the PCM mode to read out the wave data from the waveform 
memory 25 depending upon the characteristics of the installed sound source 22. After the synthesizing, the procedure 
ao returns. Thus, in the fourth embodiment, an event which can be allocated to a certain sound source device is simply 
allocated to this device upon the event detection provided that this device is installed in the system. 

Figure 25 shows an additional embodiment of the inventive musical sound generating apparatus. This embodiment 
has basically the same construction as the first embodiment shown in Figure 1 . The same components are denoted by 
the same references as those of the first embodiment to facilitate better understanding of the additional embodiment. 
35 The storage unit 1 5 can store various data such as waveform data and various programs including the system control 
program or basic program, the waveform synthesizing program and other application programs. Normaliy, the ROM 1 1 
provisionally stores these programs. However, if not, any program may be loaded into a hard disk or else in the storage 
unit 1 5. The loaded program is transferred to the RAM 13 to enable the CPU 10 to operate the inventive system of the 
musical sound generating apparatus. By such a manner, new or version-up programs can be readily installed in the sys- 
40 tern. For this purpose, a machine-readable media such as a CD-ROM (Compact Disc Read Only Memory) 51 is utilized 
to install the program. The CD-ROM 51 is set into a CD-ROM drive 52 to read out and download the program from the 
CD-ROM 51 into the storage unit 1 5 through the bus 1 2. The machine-readable media may be composed of a magnetic 
disk or an optical disk other than the CD- ROM 51 . 

A communication interface 53 is connected to an external server computer 54 through a communication network 
« 55 such as LAN (Local Area Network),public telephone network and INTERNET. If the storage unit 15 does not reserve 
needed data or program, the communication interface 53 is activated to receive the data or program from the server 
computer 54. The CPU 1 0 transmits a request to the server computer 54 thorough the interface 53 and the network 55. 
In response to the request, the server computer 54 transmits the requested data or program to the apparatus. The 
transmitted data or program is stored in the hard disk of the storage unit 1 5 to thereby complete the downloading, . 
so The inventive musical sound generating apparatus can be implemented by a personal computer which is installed 
with the needed data and programs. In such a case, the data and programs are provided to the user by means of the 
machine-readable media such as the CD-ROM 5T or a floppy disk. The machine-readable media contains instructions 
for causing the personal computer to perform the inventive musical sound generating method as described in conjunc- 
tion with the previous embodiments. Otherwise, the personal computer may receive the data and programs through the 
ss communication network 55. 

In the embodiments described above, the optional devices including the co-processor 17, DSP 21 , sound source 
22 are referred to as examples, but the optional device is not limited to these devices. The present invention can be uti- 
lized in the application systems such as personal computer, electronic musical instrument, game machine and so on in 
which the musical sound is generated. 
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As shown in the foregoing, according to the present invention, various effects can be derived. It is possible to gen- 
erate various musical sounds and to reduce a processing load required for musical sound generation. The musical 
sound can be generated at the optimum sample frequency for the configuration of the apparatus. The structure for gen- 
erating the wave data of the musical sound can be significantly simplified. The quality of the generated musical sound 
5 can be retained even in low performance hardware. The musical sound can be generated according to the performance 
information even if the volume of the performance information becomes large, 

Claims 

w 1 . A musical sound generating apparatus for creating a waveform to generate a musical sound according to perform- 
ance information, comprising: 

first waveform generator means operable for creating a waveform; 

second waveform generator means operable independently from the first waveform generator means for cre- 
is ating a waveform; 

input means for providing performance information; 

designating means for designating at least one of the first waveform generator means and the second wave- 
form generator means in correspondence with the provided performance information; 
controller means for selectively operating the designated one of the first waveform generator means and the 
second waveform generator means to create the waveform according to the provided performance information; 
and 

output means for generating -the musical sound based on the created waveform. 

A musical sound generating apparatus according to claim i , wherein the input means comprises means tor provid- 
ing performance information which contains timbre information effective to specify a timbre of the musical sound 
and timing information effective to specify a timing of generation of the musical sound, and wherein the designating 
means comprises means for designating one of the first waveform generator means and the second waveform gen- 
erator means in correspondence with the timbre information so that the output means generates the musical sound 
having the specified timber at the specified timing. 

A musical sound generating apparatus according to claim 1 , wherein the designating means includes means oper- 
able if desired for coincidently designating both of the first waveform generator means and the second waveform 
generator means so that the controller means operates both of the first waveform generator means and the second 
waveform generator means to concurrently create waveforms in parallel manner. 

A musical sound generating apparatus according to claim 1 , wherein the input means comprises means for provid- 
ing performance information effective to command concurrent generation of a plurality of musical sounds, and 
wherein the designating means comprises means for designating one of the first waveform generator means and 
the second waveform generator means according to a number of concurrent musical sounds specified by the per- 
formance information such that the designated one has a capacity sufficient to create a number of waveforms cor- 
responding to the number of the musical sounds. 

A musical sound generating apparatus according, to claim 4, wherein the designating means further comprises 
means operative when the number of the concurrent musical sounds exceeds a capacity of either of the first wave- 
form generator means and the second waveform generator means for designating both of the first waveform gen- 
erator means and the second waveform generator means to ensure complete generation of the concurrent musical 
sounds. 

6. A musical sound generating apparatus according to claim 1, wherein the first waveform generator means corn- 
so prises an external waveform generator optionally connectable to the controller means while the second waveform 

generator means comprises an internal waveform generator integrated with the controller means so that the des- 
ignating medns designates the internal waveform generator in place of the external waveform generator when the 
same is not connected to the controller means even though the external waveform generator should primarily cor- 
respond to the provided performance information. 

55 

7. A musical sound generating apparatus according to claim 1 , wherein the second waveform generator means, the 
input means, the designating means and the controller means are integrated with each other to constitute a main 
part composed of a computer, while the first waveform generator means alone constitutes a supplementary part 
which is separate from the main part and which is optionally installable in the computer. 
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8. A musical sound generating apparatus according to claim 1 , wherein the first waveform generator means is com- 
posed of a hardware module driven by the controller means, while the second waveform generator means is com- 
posed of a software module installable in the controller means. 



A musical sound generating apparatus according to claim 1 , wherein the second waveform generator means com- 
prises a plurality of digital waveform generators which are operable based on different algorithms to arithmetically 
create digital waveforms having different qualities, and wherein the controller means comprises means for selec- 
tively operating an optimal one of the digital waveform generators according to the provided performance informa- 
tion. 



10. A musical sound generating apparatus according to claim 9, wherein the second waveform generator means 
includes a digital waveform generator of a waveform memory type operable based on a relatively simple algorithm 
to create a digital waveform having a relatively low quality, and another digital waveform generator operable based 
on a relatively complicated algorithm to create another digital waveform having a relatively high quality. 

1 1 . A musical sound generating apparatus according to claim 1 , wherein the second waveform generator means com- 
prises a computerized waveform generator Operable according to a given algorithm at a variable operation speed 
to create a digital waveform by successively computing sample values of the digital waveform, and wherein the con- 
troller means comprises means for provisionally operating the computerized waveform generator to carry out trial 
creation of a model digital waveform while measuring the operation speed at which the trial creation is carried out, 
determining means for optimally determining a sampling frequency comparable to the measured operation speed, 
and means for actually operating the computerized waveform generator to enable the same to successively com- 
pute sample values of an actual digital waveform at the determined sampling frequency according to the provided 
performance information. 

12. A musical sound generating apparatus according to claim 11, wherein the determining means comprises means 
for fixing the sampling frequency to one of stepwise predetermined levels, which is lower than and closest to the 
measured operation speed. 

13. A musical sound generating apparatus according to claim 11, wherein the controller means further comprises 
changing means operative when the determined sampling frequency falls below a critical level which is defined to 
ensure a minimal quality of the digital waveform for changing the algorithm to raise the operation speed of the com- 
puterized waveform generator so that the sampling frequency can be redetermined to exceed the critical level. 

14. A musical sound generating apparatus according to claim 13, wherein the changing means comprises means for 
changing the algorithm from a complicated one to a simplified one such that the computerized waveform generator 
operates based on the simplified one of the algorithm to successively read out prestored ones of sample values to 
reproductively create the digital waveform. 

15. A musical sound generating apparatus according to claim 14, wherein the computerized waveform generator suc- 
cessively reads out prestored ones of sample values which are provisionally computed according to the compli- 
cated algorithm before the same is changed to the simplified algorithm. 

16. A sound generating apparatus for creating a digital waveform to generate a musical sound according to perform- 
ance information, comprising: 

input means for providing performance information; 

computerized waveform generator means operable based on a given algorithm at a variable operation speed 

to create a digital waveform by successively computing sample values of the digital waveform; 

trial means for provisionally operating the computerized waveform generator to carry out trial creation of a 

model digital waveform while measuring the operation speed at which the trial creation is carried out; 

determining means for optimally determining' a sampling frequency comparable to the measured operation 

speed; 

controller means for actually operating the computerized waveform generator to enable the same to succes- 
sively compute sample values of an actual digital waveform at the determined sampling frequency; and 
output means for generating the musical, sound based on the actual digital waveform according to the provided 
performance information. 



1 7. A musical sound generating method of creating a waveform to generate a musical sound according to performance 
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information, comprising the steps of: 

preparing a first waveform generator operable for creating a waveform; 

preparing a second waveform generator operable independently from the first waveform generator for creating 
s a waveform; 

providing performance information; 

designating at least one of the first waveform generator and the second waveform generator in correspond- 
ence with the provided performance information; 

selectively operating the designated one of the first waveform generator and the second waveform generator 
w by means of a controller to create the waveform according to the provided performance information; and 

generating the musical sound based on the created waveform. 

18. A musical sound generating method according to claim 17, wherein the providing step comprises providing per- 
formance information which contains timbre information effective to specify a timbre of the musical sound and tim- 
rs ing information effective to specify a timing of generation of the musical sound, and wherein the designating step 
comprises designating one of the first waveform generator and the second waveform generator in correspondence 
with the timbre information so that the musical sound having the specified timber is generated at the specified tim- 
ing. 

so 19. A musical sound generating method according to claim 17, wherein the designating step includes, if desired, coin- 
cidently designating both of the first waveform generator and the second waveform generator so that the controller 
operates both of the first waveform generator and the second waveform generator to concurrently create wave- 
forms in parallel manner. 

25 20. A musical sound generating method according to claim 17, wherein the providing step comprises providing per- 
formance information effective to command concurrent generation of a plurality of musical sounds, and wherein the 
designating step comprises designating one of the first waveform generator and the second waveform generator 
according to a number of concurrent musical sounds specified by the performance information such that the des- 
ignated one has a capacity sufficient to create a number of waveforms corresponding to the number of the musical 

30 sounds. 

21. A musical sound generating method according to claim 20, wherein the designating step further comprises desig- 
nating both of the first waveform generator and the second waveform generator to ensure complete generation of 
the concurrent musical sounds when the number of the concurrent musical sounds exceeds a capacity of either of 

35 the first waveform generator and the second waveform generator. 

22. A musical sound generating method according to claim 17, wherein the preparing steps comprise preparing the 
first waveform generator composed for an external waveform generator optionally connectable to the controller and 
the second waveform generator composed of an internal waveform generator integrated with the controller so that 

40 ihe internal waveform generator is designated in place of the external waveform generator when the same is not 
connected to the controller even though the external waveform generator should primarily correspond to the pro- 
vided performance information. 

23. A musical sound generating method according to claim 17, wherein the preparing steps comprise preparing the 
45 first waveform generator composed of a hardware module driven by the controller and the second waveform gen- 
erator composed of a software module installable in the controller. 

24. A musical sound generating method according to claim 17, wherein the preparing step comprises preparing the 
second waveform generator copmosed of a plurality of digital waveform generators which are operable based on 

so different algorithms to arithmetically create digital waveforms having different qualities, and wherein the operating 
step comprises selectively operating an optimal one of the digital waveform generators according to the provided 
performance information. 

25. A musical sound generating method according to claim 24, wherein the preparing step comprises preparing the 
55 second waveform generator including a digital waveform generator of a waveform memory type operable based on 

a relatively simple algorithm to create a digital waveform having a relatively low quality, and another digital wave- 
form generator operable based on a relatively complicated algorithm to create another digital waveform having a 
relatively high quality. 
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26. A musical sound generating method according to claim 17, wherein the preparing step comprises preparing the 
second waveform generator composed of a computerized waveform generator operable according to a given algo- 
rithm at a variable operation speed to create a digital waveform by successively computing sample values of the 
digital waveform, and wherein the operating step comprises steps of provisionally operating the computerized 
waveform generator to carry out trial creation of a mode! digital waveform white measuring the operation speed at 
which the trial creation is carried out, optimally determining a sampling frequency comparable to the measured 
operation speed, and actually operating the computerized waveform generator to enable the same to successively 
compute sample values of an actual digital waveform at the determined sampling frequency according to the pro- 
vided performance information. 

27. A musical sound generating method according to claim 26, wherein the determining step comprises fixing the sam- 
pling frequency to one of stepwise predetermined levels, which is lower than and closest to the measured operation 
speed. 

28. A musical sound generating method according to claim 26, wherein the operating step further comprises changing 
the algorithm to raise the operation speed of the computerized waveform generator so that the sampling frequency 
can be redetermined to exceed the critical level when the determined sampling frequency falls below a critical level 
which is defined to ensure a minimalquality of the digital waveform. 

29. A musical sound generating method according to claim 28, wherein the changing step comprises changing the 
algorithm from a complicated one to a simplified one such that the computerized waveform generator operates 
based on the simplified one of the algorithm to successively read out prestored ones of sample values to reproduc- 
tively create the digital waveform. 

30. A musical sound generating method according to claim 29, wherein the preparing step comprises preparing the 
computerized waveform generator which successively reads out prestored ones of sample values which are provi- 
sionally computed according to the complicated algorithm before the same is changed to the simplified algorithm. 

31. A sound generating method of creating a digital waveform to generate a musical sound according to performance 
information the method, comprising the steps of: 

providing performance information; 

preparing a computerized waveform generator operable based on a given algorithm at a variable operation 
speed to create a digital waveform by successively computing sample values of the digital waveform; 
provisionally operating the computerized waveform generator to carry out trial creation of a model digital wave- 
form while measuring the operation speed at which the trial creation is carried out; 
optimally determining a sampling frequency comparable to the measured operation speed; 
actually operating the computerized waveform generator to enable the same to successively compute sample 
values of an actual digital waveform at the determined sampling frequency; and 

generating the musical sound based on the actual digital waveform according to the provided performance 
information. 

32. A machine readable media containing instructions for causing said machine to perform a method of creating a 
waveform to generate a musical sound according to performance information, the method comprising the steps of: 

preparing a first waveform generator operable for creating a waveform; 

preparing a second waveform generator operable independently from the first waveform generator for creating 
a waveform; 

providing performance information; 

designating at least one of the first waveform generator and the second waveform generator in correspond- 
ence with the provided performance information; 

selectively operating the designated one of the first waveform generator and the second waveform generator 
by means of a controller to create the waveform according to the provided performance information; and 
generating the musical sound based on the created waveform. 

33. A machine readable media according to claim 32, wherein the providing step comprises providing performance 
information which contains timbre information effective to specify a timbre of the musical sound and timing informa- 
tion effective to specify a timing of generation of the musical sound, and wherein the designating step comprises 
designating one of the first waveform generator and the second, waveform generator in correspondence with the 
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timbre information so that the musical sound having the specified timber is generated at the specified timing. 

34. A machine readable media according to claim 30, wherein the designating step includes, if desired, coincidentiy 
designating both of the first waveform generator and the second waveform generator so that the controller operates 
both of the first waveform generator and the second waveform generator to concurrently create waveforms in par- 
allel manner. 

35. A machine readable media according to claim 32, wherein the providing step comprises providing performance 
information effective to command concurrent generatioii of a plurality of musical sounds, and wherein the designat- 
ing step comprises designating one of the first waveform generator and the second waveform generator according 
to a number of concurrent musical sounds specified by the performance information such that the designated one 
has a capacity sufficient to create a number of waveforms corresponding to the number of the musical sounds. 

36. A machine readable media according to claim 35, wherein the designating step further comprises designating both 
of the first waveform generator and the second waveform generator to ensure complete generation of the concur- 
rent musical sounds when the number of the concurrent musical sounds exceeds a capacity of either of the first 
waveform generator and the second waveform generator. 

37. A machine readable media according to claim 32, wherein the preparing steps comprise preparing the first wave- 
form generator composed for an external waveform generator optionally connectable to the controller and the sec- 
ond waveform generator composed of an internal waveform generator integrated with the controller so that the 
internal waveform generator is designated in place of the external waveform generator when the same is not con- 
nected to the controller even though the external waveform generator should primarily correspond to the provided 
performance information. 

38. A machine readable media according to claim 32, wherein the preparing steps comprise preparing the first wave- 
form generator composed of a hardware module driven by the controller and the second waveform generator com- 
posed of a software module installable in the controller. 

39. A machine readable media according to claim 32, wherein the preparing step comprises preparing the second 
waveform generator copmosed of a plurality of digital waveform generators which are operable based on different 
algorithms to arithmetically create digital waveforms having different qualities, and wherein the operating step com- 
prises selectively operating an optimal one of the digital waveform generators according to the provided perform- 
ance information. 

40. A machine readable media according to claim 39, wherein the preparing step comprises preparing the second 
waveform generator including a digital waveform generator of a waveform memory type operable based on a rela- 
tively simple algorithm to create a digital waveform having a relatively low quality, and another digital waveform gen- 
erator operable based on a relatively complicated algorithm to create another digital waveform having a relatively 
high quality. 

41. A machine readable media according to claim 32, wherein the preparing step comprises preparing the second 
waveform generator composed of a computerized waveform generator operable according to a given algorithm at 
a variable operation speed to create a digital waveform by successively computing sample values of the digital 
waveform, and wherein the operating step comprises steps of provisionally operating the computerized waveform 
generator to carry out trial creation of a model digital waveform while measuring the operation speed at which the 
trial creation is carried out, optimally determining a sampling frequency comparable to the measured operation 
speed, and actually operating the computerized waveform generator to enable the same to successively compute 
sample values of an actual digital waveform at the determined sampling frequency according to the provided per- 
formance information. 

42. A machine readable media according to claim 41 , wherein the determining step comprises fixing the sampling fre- 
quency to one of stepwise predetermined levels, which is lower than and closest to the measured operation speed. 

43. A machine readable media according to claim 41, wherein the operating step further comprises changing the algo- 
rithm to raise the operation speed of the computerized waveform generator so that the sampling frequency can be 
redetermined to exceed the critical level when the determined sampling frequency falls below a critical level which 
is defined to ensure a minimal quality of the digital waveform. 
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44. A machine readable media according to claim 43, wherein the changing step comprises changing the algorithm 
from a complicated one to a simplified one such that the computerized waveform generator operates based on the 
simplified one of the algorithm to successively read out prestored ones of sample values to reproductively create 
the digital waveform. 

45. A machine readable media according to claim 44, wherein the preparing step comprises preparing the computer- 
ized waveform generator which successively reads out prestored ones of sample values which are provisionally 
computed according to the complicated algorithm before the same is changed to the simplified algorithm. 

46. A machine readable media containing instructions for causing said machine to perform a method of creating a dig- 
ital waveform to generate a musical sound according to performance information, the method comprising the steps 
of: 

providing performance information; 

preparing a computerized waveform generator operable based on a given algorithm at a variable operation 
speed to create a digital waveform by successively computing sample values of the digital waveform; 
provisionally operating the computerized waveform generator to carry out trial creation of a model digital wave- 
form while measuring the operation speed at which the trial creation is carried out; 
optimally determining a sampling frequency comparable to the measured operation speed; 
actually operating the computerized waveform generator to enable the same to successively compute sample 
values of an actual digital waveform at the determined sampling frequency; and 

generating the musical sound based on the actual digital waveform according to the provided performance 
information. 



EP 0 747 877 A2 




EP 0 747 877 A2 




EP 0 747 877 A2 



30 - 
12 

31- 



FIGURE 


3 


CPU SYSTEM 




SOUND 




SOURCE 


, i 


i 


SYSTEM 




* • — 1 



^32 



PERIPHERAL 
DEVICES 



22 



FIGURE 4A 



SOUND 
SOURCE 



DAC 



WAVEFORM 
MEMORY 



-25 



.23 

* OUTPUT 



FIGURE 4B 



21- 



DSP 



DAC 



RAM — 24 



^23 

-OUTPUT 



EP 0 747 877 A2 



LO 
LU 




EP 0 747 877 A2 



FIGURE 6 



OS AREA. 



WAVEFORM SYNTHESIZING 
PROGRAM AREA 



APPLICATION PROGRAM 
AREA(l) 



APPLICATION PROGRAM 
AREA(n) 



DATA AREA 



WAVE DATA AREA " WAVE" 



EP 0 747 877 A2 



FIGURE 7 



( CPU SYSTEM TASK ) 1 



INITIALIZATION 



-S1 



SYSTEM 

ADMINISTRATION (OS) 






APPLICATION (1) 






WAVEFORM 

SYNTHESIZING 

PROGRAM 






APPLICA 


TION(n) 



S2 



-S3 



-S4 



S5 



EP 0 747 877 A2 



FIGURE 8 



WAVEFORM SYNTHESIZING A 
PROGRAM J 

T 



OPERATING MODE SETUP 
AND HARDWARE CHECK 



-Sa1 



WAVEFORM LOADING 



Sa2 



NO 



\ M( 



W SETFLG= 
jYES 



CPU SYNTHESIZING 
MODE 



Sa3 
Sa4 
NO 



YES 



(IF ENBLFLG^l 



Sa5 



Sa6 



Sa11 




YES 



IF ALLOCATION MODE \ 
IS EITHER OF CPU l 
SELECT MODE AND 
SOUND SOURCE SELECT , 
MODE 



PERFORMANCE 
INFORMATION 
PROCESSING 

I 



Sa7 



NO 



YES 



© 



' IF CPU WAVEFORM 

GENERATION 
\ COMMAND IS ISSUED 



|YES 7 Sa8 



WAVEFORM 

SYNTHESIZING 

COMPUTATION 



Sa9 



NO 



IF PROGRAM IS 
TERMINATED 



> 



|YES / $a 1Q 



SETFLG^O 



EP 0 747 877 A2 



FIGURE 10 



BUSY— 0 



Sa18 



Fs - mx margin — -Sa1 9 



TCOUNTxTt 




SELECT Fs OUT OF 
32,44.1,48,50kHz 
(SMALLER AND 
CLOSEST TO Fs) 



ALARM ,AND 
CALL BACKUP 
WAVEFORM 
COMPUTATION 
MODE 



m BACKUP WAVEFORMX N0 
< COMPUTATION MODE X 
\ IS SPECIFIED 



Sa26 



Sa25 



YES 



'IF PROGRAM IS N 
TERMINATED 



YES 



WAVEFORM COMPUTATION BY 
PRIMARY MODE, AND WAVEFORM 
MEMORY READOUT MODE 
AUTOMATICALLY SELECTED 
FOR SYNTHESIZING 



ENBLFLG— 1 
DACENBL^-1 
SETFLG- — 1 



-Sa22 



Sa27 



SETFLG^O 



EP 0 747 877 A2 



LU 

ZD 
O 




EP 0 747 877 A2 



FIGURE 12 



(STEP Sa2) 



c 



WAVEFORM LOADING 
PROCESS 



IF MIDI SAMPLE 
DUMP COMMAND 
IS RECEIVED 



YES 



Sb1 
\ NO 



Sb4 



IF WAVE DATA IS 
TRANSFERRED FROM 
DATA I/F 



YES 



SAMPLE DUMP 

RECEIVING 

PROCESS 



NO 



IF DATA 

RECEIVING 

FINISHES 



y 



Sb2 



Sb3 



Sb5 



IF ACCESS EVENT 
IS DETECTED FOR 
DISK 



i NO 







DISK DATA CHECK 






/Sbl 



IF WAVE DATA EXISTS^L 
^ Sb8 



lYES 



READOUT AND TRANSFER 
WAVE DATA 
RAM "WAVE" ^DISC 



NO 



Sb9 



IF ROADING FINISHES) 
YESl . 

|ret| 



EP 0 747 877 A2 



FIGURE 13 



(STEP Sal5) 



C 



SAMPLE VALUE 
COMPUTATION 



Sc1 



'IF CO-PROCESSOR \ NO 
l EXISTS .. 



Sc2 



YES 



SAMPLE VALUE 
COMPUTATION 
WITH CPU AND 
CO-PROCESSOR 



Sc3 



SAMPLE VALUE 
COMPUTATION 
WITH CPU ONLY 



EP0 747 877 A2 



FIGURE 14 



(STEP Sc3) 



/ SAMPLE VALUE \ 

COMPUTATION 
V WITH CPU J 




Sd3 



YES 



Sd2 



IF WAVEFORM 
MEMORY READOUT 
MODE IS SET 



FM WAVEFORM 
SYNTHESIZING 
COMPUTATION 



YES 



_L 



Sd5 



IF HARMONICS 
'SYNTHESIZING 
Sd4\MODE IS SET 



NO 



WAVEFORM MEMORY 
READOUT PROCESS 
USING WAVE DATA 
LOADED IN AREA 
" WAVE" OF RAM OR 
STORED IN ROM 



YES, 



Sd7 



IF PHYSICAL 
MODEL 

SYNTHESIZING 
MODE IS SET 



Sd6 



SAMPLE VOLUE 
COMPUTATION BY 
HARMONICS 
SYNTHESIZING MODE 



YES 



\NO 

n 



Sd8 



SAMPLE VALUE 
COMPUTATION 
BY PHYSICAL 
MODEL 

SYNTHESIZING 
MODE 



Sd9 L^g^j 



EP 0 747 877 A2 



FIGURE 15 



(STEP Sa34) 



SYNTHESIS OF WAVEFORM 
USING SELECTED HARDWARE 
SOUND SOURCE 



f) 



EVENT DETECTING 
ADMINISTRATION 



<: 



IF SOUND SOURCE 
SELECT MODE 



YES 



Se1 

,Se2 



NO 



Se3 



IF SOUND SOURCE 
SYNTHESIZING CONDITION 
IS SATISFIED 



Se5 v 



YES 



Se4. 



NO 



SeS 



[TRUNCATING 
: PROCESS 



Se8 

NO 



VOICE ALLOCATION 



' If \ 

ENBLFIG=1 J ?37 



lYES 



VOICE ALLOCATION 
TO CPU SYNTHESIZING 
MODE 



SYNTHESIS WITH 
SELECTED HARDWARE 



0- 



IF ALLOCATION \ 
COMMAND EXISTS FOR 
CPU WAVEFORM 
SYNTHESIS J 



YES 



WAVEFORM SYNTHESIS 
COMPUTATION 



^Se9 



-Se10 



[retJ 



EP 0 747 877 A2 



FIGURE 16 



NO 



Se11 



IF CPU SYNTHESIZING 
CONDITION IS COMPLIED 



Se13 




Se12 



FIGURE 17 



NO 



/"TIMER PROCESS > 
^ (INTERRUPT) J 




TCOUNT— TCOUNT + 1 



OTHER MISCELLANEOUS 
TIMER PROCESSES 



-Sf2 



-Sf3 



EP 0 747 877 A2 



(3 



FIGURE 18 

(STEP Sa34) 

SYNTHESIZING WAVEFORM 
WITH SELECTED HARDWARE 



Sg3 



EVENT DETECTING 
ADMINISTRATION 



-Sgl 



SYSTEM CHECK FOR VOICE ALLOCATION 
CPU 

(WAVEFORM MEMORY 
READOUT MODE) 



SOUND SOURCE 



VOICE ALLOCATION TO 
SOUND SOURCE , 



VOICE ALLOCATION 
TO CPU 



V 



SYNTHESIZING WAVEFORM 
WITH SELECTED HARDWARE 

PCM SYNTHESIS WITH 
BUILT-IN WAVEROM MEMORY, 
FM SYNTHESISER PHYSICAL 
MODEL SYTHESIS 



.Sg4 



NO 



IF ALLOCATION COMMAND 
EXISTS FOR CPU SYNTHESIS 



YES 



r 



SYNTHESIZING WAVEFORM 
BY READING OUT WAVE 
DATA FROM AREA "WAVE" 
AT SAMPLING FREQUENCY 
is 



Sg6 



■Sg7 



RET. 



EP 0 747 877 A2 



FIGURE 19 

(STEP Sa34) 

SYNTHESIZING WAVEFORM 
WITH SELECTED HARDWARE 



EVENT DETECTING 
ADMINISTRATION 



-SM 



Sh2 



SYSTEM CHECK FOR VOICE ALLOCATION 
SYNTHESIS 
WITH BOTH OF CPU 
SOUND SOURCE CPU AND SOUND SOURCE k 



Sh3 



VOICE ALLOCATION TO 
SOUND SOURCE 



VOICE ALLOCATION 
TO CPU 



SYNTHESIZING WAVEFORM 
BY SELECTED HARDWARE 



Sh6 



— Sh4 



-Sh5 



if allocation command 
exists for cpu 

[yes 



> 



NO 



SYNTHESIZING COMPUTATION 
AT SAMPLING FREQUENCY 



-Sh7 



EP 0 747 877 A2 



FIGURE 20 



(STEP Sa34) 



SYNTHESIZING PROCESS 
WITH SELECTED HARDWARE 



VOICE ALLOCATION 



SYNTHESIZING WAVEFORM 
WITH SELECTED HARDWARE 







-Si2 



EP 0 747 877 A2 




EP 0 747 877 A2 




EP 0 747 877 A2 




